]> git.saurik.com Git - wxWidgets.git/commitdiff
added wxApp::Yield()
authorVadim Zeitlin <vadim@wxwidgets.org>
Fri, 19 Oct 2001 18:29:32 +0000 (18:29 +0000)
committerVadim Zeitlin <vadim@wxwidgets.org>
Fri, 19 Oct 2001 18:29:32 +0000 (18:29 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@12095 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

19 files changed:
docs/latex/wx/app.tex
docs/latex/wx/function.tex
include/wx/app.h
include/wx/gtk/app.h
include/wx/gtk1/app.h
include/wx/mac/app.h
include/wx/motif/app.h
include/wx/msw/app.h
include/wx/os2/app.h
include/wx/utils.h
src/common/init.cpp
src/common/utilscmn.cpp
src/gtk/app.cpp
src/gtk1/app.cpp
src/mac/app.cpp
src/mac/carbon/app.cpp
src/motif/app.cpp
src/msw/app.cpp
src/os2/app.cpp

index c71c82dbecb988a152a8070971314b0bdf251c22..2a3ba6fb0eb120ab306199acb101fbe58f817f0a 100644 (file)
@@ -603,3 +603,29 @@ This function currently only has effect under GTK.
 
 \docparam{flag}{If TRUE, the app will use the best visual.}
 
+\membersection{wxApp::Yield}{wxappyield}
+
+\func{bool}{Yield}{\param{bool}{ onlyIfNeeded = FALSE}}
+
+Yields control to pending messages in the windowing system. This can be useful, for example, when a
+time-consuming process writes to a text window. Without an occasional
+yield, the text window will not be updated properly, and on systems with
+cooperative multitasking, such as Windows 3.1 other processes will not respond.
+
+Caution should be exercised, however, since yielding may allow the
+user to perform actions which are not compatible with the current task.
+Disabling menu items or whole menus during processing can avoid unwanted
+reentrance of code: see \helpref{::wxSafeYield}{wxsafeyield} for a better
+function.
+
+Note that Yield() will not flush the message logs. This is intentional as
+calling Yield() is usually done to quickly update the screen and popping up a
+message box dialog may be undesirable. If you do wish to flush the log
+messages immediately (otherwise it will be done during the next idle loop
+iteration), call \helpref{wxLog::FlushActive}{wxlogflushactive}.
+
+Calling Yield() recursively is normally an error and an assert failure is
+raised in debug build if such situation is detected. However if the the 
+{\it onlyIfNeeded} parameter is {\tt TRUE}, the method will just silently
+return {\tt FALSE} instead.
+
index a341f54d0d11d6d11e356ebdb6cd71cd0a313eb5..dc9310d0bf1b25f8764ab378e9bad8c012f94944 100644 (file)
@@ -2143,22 +2143,10 @@ See also \helpref{wxGetResource}{wxgetresource}, \helpref{wxConfigBase}{wxconfig
 
 \func{bool}{wxYield}{\void}
 
-Yields control to pending messages in the windowing system. This can be useful, for example, when a
-time-consuming process writes to a text window. Without an occasional
-yield, the text window will not be updated properly, and on systems with
-cooperative multitasking, such as Windows 3.1 other processes will not respond.
-
-Caution should be exercised, however, since yielding may allow the
-user to perform actions which are not compatible with the current task.
-Disabling menu items or whole menus during processing can avoid unwanted
-reentrance of code: see \helpref{::wxSafeYield}{wxsafeyield} for a better
-function.
+Calls \helpref{wxApp::Yield}{wxappyield}.
 
-Note that wxYield will not flush the message logs. This is intentional as
-calling wxYield is usually done to quickly update the screen and popping up a
-message box dialog may be undesirable. If you do wish to flush the log
-messages immediately (otherwise it will be done during the next idle loop
-iteration), call \helpref{wxLog::FlushActive}{wxlogflushactive}.
+This function is kept only for backwards compatibility, please use the
+wxApp method instead in any new code.
 
 \wxheading{Include files}
 
index 36e9e1979064857be0e44169246541d53fbee75a..d30e19cd8dd8768398075f16c7ff8043dd3112af 100644 (file)
@@ -65,9 +65,6 @@ public:
 
     // the virtual functions which may/must be overridden in the derived class
     // -----------------------------------------------------------------------
-#ifdef __DARWIN__
-    virtual ~wxAppBase() { }
-#endif
 
         // called during the program initialization, returning FALSE from here
         // prevents the program from continuing - it's a good place to create
@@ -135,6 +132,17 @@ public:
         // process the first event in the event queue (blocks until an event
         // apperas if there are none currently)
     virtual void Dispatch() = 0;
+
+        // process all currently pending events right now
+        //
+        // it is an error to call Yield() recursively unless the value of
+        // onlyIfNeeded is TRUE
+        //
+        // WARNING: this function is dangerous as it can lead to unexpected
+        //          reentrancies (i.e. when called from an event handler it
+        //          may result in calling the same event handler again), use
+        //          with _extreme_ care or, better, don't use at all!
+    virtual bool Yield(bool onlyIfNeeded = FALSE) = 0;
 #endif // wxUSE_GUI
 
     // application info: name, description, vendor
@@ -285,6 +293,11 @@ public:
     static wxAppInitializerFunction GetInitializerFunction()
         { return m_appInitFn; }
 
+    // needed to avoid link errors
+#ifdef __DARWIN__
+    virtual ~wxAppBase() { }
+#endif
+
     // process all events in the wxPendingEvents list
     virtual void ProcessPendingEvents();
 
index 2681dea2537e0eaf12f54f33bdfa71e27e34d1d9..e031a2ce9f57e48fa50487b2c2887a13fed79fc8 100644 (file)
@@ -1,5 +1,5 @@
 /////////////////////////////////////////////////////////////////////////////
-// Name:        app.h
+// Name:        wx/gtk/app.h
 // Purpose:
 // Author:      Robert Roebling
 // Id:          $Id$
@@ -46,6 +46,7 @@ public:
     virtual bool Initialized();
     virtual bool Pending();
     virtual void Dispatch();
+    virtual bool Yield(bool onlyIfNeeded = FALSE);
 
     virtual wxIcon GetStdIcon(int which) const;
 
index 2681dea2537e0eaf12f54f33bdfa71e27e34d1d9..e031a2ce9f57e48fa50487b2c2887a13fed79fc8 100644 (file)
@@ -1,5 +1,5 @@
 /////////////////////////////////////////////////////////////////////////////
-// Name:        app.h
+// Name:        wx/gtk/app.h
 // Purpose:
 // Author:      Robert Roebling
 // Id:          $Id$
@@ -46,6 +46,7 @@ public:
     virtual bool Initialized();
     virtual bool Pending();
     virtual void Dispatch();
+    virtual bool Yield(bool onlyIfNeeded = FALSE);
 
     virtual wxIcon GetStdIcon(int which) const;
 
index 8381c919d23bd6793ff8f84cc8c63687e33cc8b4..50c0d60f835e1d42bba677b6f7524dbe0638779f 100644 (file)
@@ -51,6 +51,7 @@ class WXDLLEXPORT wxApp: public wxAppBase
   virtual bool Initialized();
   virtual bool Pending() ;
   virtual void Dispatch() ;
+  virtual bool Yield(bool onlyIfNeeded = FALSE);
 
   virtual wxIcon GetStdIcon(int which) const;
   virtual void SetPrintMode(int mode) { m_printMode = mode; }
index f262298f2f0f6f58c299a2f86919b1bafae5a877..092e6515a7f008b8a06daa97b08dff5fbfe0e000 100644 (file)
@@ -53,6 +53,7 @@ public:
     virtual bool Initialized();
     virtual bool Pending();
     virtual void Dispatch();
+    virtual bool Yield(bool onlyIfNeeded = FALSE);
 
     virtual bool OnInitGui();
 
index dad32116b98f0e15d81a9d3902f18d28438fb23e..e361fa3ca8d6c2f627747ec35e908b0dd51294a6 100644 (file)
@@ -41,6 +41,7 @@ public:
     virtual bool Initialized();
     virtual bool Pending();
     virtual void Dispatch();
+    virtual bool Yield(bool onlyIfNeeded = FALSE);
 
     virtual wxIcon GetStdIcon(int which) const;
 
index 31d405384db6435064beb7d13ad534de3f4511c6..2c631f549436135da974b3873152dec514a0cc7a 100644 (file)
@@ -76,6 +76,7 @@ public:
     virtual bool Initialized(void);
     virtual bool Pending(void) ;
     virtual void Dispatch(void);
+    virtual bool Yield(bool onlyIfNeeded = FALSE);
 
     virtual wxIcon GetStdIcon(int which) const;
 
index a737731cace3befbc23e959df69cb6e466dca3dd..a60616f433f647046b386e40c5f16e4ee5f260e5 100644 (file)
@@ -20,7 +20,6 @@
     #pragma interface "utils.h"
 #endif
 
-#include "wx/setup.h"
 #include "wx/object.h"
 #include "wx/list.h"
 #include "wx/filefn.h"
index 390dced3de669ff46f3a40da23f478caf15d049f..41b3d29330f87cd820ffa60a49845aff2794fe44 100644 (file)
@@ -76,13 +76,6 @@ void WXDLLEXPORT wxExit()
     abort();
 }
 
-// Yield to other apps/messages
-bool WXDLLEXPORT wxYield()
-{
-    // do nothing
-    return TRUE;
-}
-
 // Yield to other apps/messages
 void WXDLLEXPORT wxWakeUpIdle()
 {
index 2b812d81bfe2dd010e4f3798584a9e60c7bfc583..724f54de2a05e8435fcf737fba6c4aa6a7587a12 100644 (file)
@@ -36,6 +36,7 @@
     #include "wx/log.h"
 
     #if wxUSE_GUI
+        #include "wx/app.h"
         #include "wx/window.h"
         #include "wx/frame.h"
         #include "wx/menu.h"
@@ -1312,4 +1313,25 @@ long wxExecute(const wxString& command,
     return wxDoExecuteWithCapture(command, output, &error);
 }
 
+// ----------------------------------------------------------------------------
+// wxApp::Yield() wrappers for backwards compatibility
+// ----------------------------------------------------------------------------
+
+bool wxYield()
+{
+#if wxUSE_GUI
+    return wxTheApp && wxTheApp->Yield();
+#else
+    return FALSE;
+#endif
+}
+
+bool wxYieldIfNeeded()
+{
+#if wxUSE_GUI
+    return wxTheApp && wxTheApp->Yield(TRUE);
+#else
+    return FALSE;
+#endif
+}
 
index 60780e3d703dcd03c7381f1fb721219c37de144a..0ef365ec055a62bd6ecd44daee068b277a3c089a 100644 (file)
@@ -83,10 +83,21 @@ void wxExit()
 // wxYield
 //-----------------------------------------------------------------------------
 
-static bool gs_inYield = FALSE;
-
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
+    // MT-FIXME
+    static bool s_inYield = FALSE;
+
+    if ( s_inYield )
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( wxT("wxYield called recursively" ) );
+        }
+
+        return FALSE;
+    }
+
 #if wxUSE_THREADS
     if ( !wxThread::IsMain() )
     {
@@ -95,19 +106,14 @@ bool wxYield()
     }
 #endif // wxUSE_THREADS
 
-#ifdef __WXDEBUG__
-    if (gs_inYield)
-        wxFAIL_MSG( wxT("wxYield called recursively" ) );
-#endif
-
-    gs_inYield = TRUE;
+    s_inYield = TRUE;
 
     if (!g_isIdle)
     {
         // We need to remove idle callbacks or the loop will
         // never finish.
-        gtk_idle_remove( wxTheApp->m_idleTag );
-        wxTheApp->m_idleTag = 0;
+        gtk_idle_remove( m_idleTag );
+        m_idleTag = 0;
         g_isIdle = TRUE;
     }
 
@@ -121,29 +127,18 @@ bool wxYield()
     /* it's necessary to call ProcessIdle() to update the frames sizes which
        might have been changed (it also will update other things set from
        OnUpdateUI() which is a nice (and desired) side effect) */
-    while (wxTheApp->ProcessIdle()) { }
+    while ( ProcessIdle() )
+    {
+    }
 
     // let the logs be flashed again
     wxLog::Resume();
 
-    gs_inYield = FALSE;
+    s_inYield = FALSE;
 
     return TRUE;
 }
 
-//-----------------------------------------------------------------------------
-// wxYieldIfNeeded
-// Like wxYield, but fails silently if the yield is recursive.
-//-----------------------------------------------------------------------------
-
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-
-    return wxYield();
-}
-
 //-----------------------------------------------------------------------------
 // wxWakeUpIdle
 //-----------------------------------------------------------------------------
index 60780e3d703dcd03c7381f1fb721219c37de144a..0ef365ec055a62bd6ecd44daee068b277a3c089a 100644 (file)
@@ -83,10 +83,21 @@ void wxExit()
 // wxYield
 //-----------------------------------------------------------------------------
 
-static bool gs_inYield = FALSE;
-
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
+    // MT-FIXME
+    static bool s_inYield = FALSE;
+
+    if ( s_inYield )
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( wxT("wxYield called recursively" ) );
+        }
+
+        return FALSE;
+    }
+
 #if wxUSE_THREADS
     if ( !wxThread::IsMain() )
     {
@@ -95,19 +106,14 @@ bool wxYield()
     }
 #endif // wxUSE_THREADS
 
-#ifdef __WXDEBUG__
-    if (gs_inYield)
-        wxFAIL_MSG( wxT("wxYield called recursively" ) );
-#endif
-
-    gs_inYield = TRUE;
+    s_inYield = TRUE;
 
     if (!g_isIdle)
     {
         // We need to remove idle callbacks or the loop will
         // never finish.
-        gtk_idle_remove( wxTheApp->m_idleTag );
-        wxTheApp->m_idleTag = 0;
+        gtk_idle_remove( m_idleTag );
+        m_idleTag = 0;
         g_isIdle = TRUE;
     }
 
@@ -121,29 +127,18 @@ bool wxYield()
     /* it's necessary to call ProcessIdle() to update the frames sizes which
        might have been changed (it also will update other things set from
        OnUpdateUI() which is a nice (and desired) side effect) */
-    while (wxTheApp->ProcessIdle()) { }
+    while ( ProcessIdle() )
+    {
+    }
 
     // let the logs be flashed again
     wxLog::Resume();
 
-    gs_inYield = FALSE;
+    s_inYield = FALSE;
 
     return TRUE;
 }
 
-//-----------------------------------------------------------------------------
-// wxYieldIfNeeded
-// Like wxYield, but fails silently if the yield is recursive.
-//-----------------------------------------------------------------------------
-
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-
-    return wxYield();
-}
-
 //-----------------------------------------------------------------------------
 // wxWakeUpIdle
 //-----------------------------------------------------------------------------
index 095156baa187df2d8d20e785a23836b7bc68688e..ade0e6938efc7c63077b31986b3a14aad42592db 100644 (file)
@@ -6,7 +6,7 @@
 // Created:     ??/??/98
 // RCS-ID:      $Id$
 // Copyright:   (c) AUTHOR
-// Licence:    wxWindows licence
+// Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
 #ifdef __GNUG__
@@ -43,7 +43,7 @@
 
 #ifndef __DARWIN__
   #if __option(profile)
-       #include <profiler.h>
+    #include <profiler.h>
   #endif
 #endif
 
@@ -78,18 +78,18 @@ END_EVENT_TABLE()
 #endif
 
 
-const short    kMacMinHeap = (29 * 1024) ;
+const short    kMacMinHeap = (29 * 1024) ;
 // platform specific static variables
 
 const short kwxMacMenuBarResource = 1 ;
 const short kwxMacAppleMenuId = 1 ;
 
-RgnHandle                      wxApp::s_macCursorRgn = NULL;
-wxWindow*                      wxApp::s_captureWindow = NULL ;
-int                                    wxApp::s_lastMouseDown = 0 ;
-long                                   wxApp::sm_lastMessageTime = 0;
+RgnHandle            wxApp::s_macCursorRgn = NULL;
+wxWindow*            wxApp::s_captureWindow = NULL ;
+int                    wxApp::s_lastMouseDown = 0 ;
+long                     wxApp::sm_lastMessageTime = 0;
 
-bool   wxApp::s_macDefaultEncodingIsPC = true ;
+bool    wxApp::s_macDefaultEncodingIsPC = true ;
 bool wxApp::s_macSupportPCMenuShortcuts = true ;
 long wxApp::s_macAboutMenuItemId = wxID_ABOUT ;
 wxString wxApp::s_macHelpMenuTitleName = "&Help" ;
@@ -100,8 +100,8 @@ pascal OSErr AEHandleODoc( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandleODoc( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEODoc( (AppleEvent*) event , reply) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEODoc( (AppleEvent*) event , reply) ;
 }
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
@@ -110,8 +110,8 @@ pascal OSErr AEHandleOApp( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandleOApp( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEOApp( (AppleEvent*) event , reply ) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEOApp( (AppleEvent*) event , reply ) ;
 }
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
@@ -120,8 +120,8 @@ pascal OSErr AEHandlePDoc( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandlePDoc( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEPDoc( (AppleEvent*) event , reply ) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEPDoc( (AppleEvent*) event , reply ) ;
 }
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
@@ -130,254 +130,254 @@ pascal OSErr AEHandleQuit( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandleQuit( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEQuit( (AppleEvent*) event , reply) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEQuit( (AppleEvent*) event , reply) ;
 }
 
 OSErr wxApp::MacHandleAEODoc(const AppleEvent *event , AppleEvent *reply)
 {
     SysBeep(40) ;
-       ProcessSerialNumber PSN ;
-       PSN.highLongOfPSN = 0 ;
-       PSN.lowLongOfPSN = kCurrentProcess ;
-       SetFrontProcess( &PSN ) ;
-       return noErr ;
+    ProcessSerialNumber PSN ;
+    PSN.highLongOfPSN = 0 ;
+    PSN.lowLongOfPSN = kCurrentProcess ;
+    SetFrontProcess( &PSN ) ;
+    return noErr ;
 }
 
 OSErr wxApp::MacHandleAEPDoc(const AppleEvent *event , AppleEvent *reply)
 {
-       return noErr ;
+    return noErr ;
 }
 
 OSErr wxApp::MacHandleAEOApp(const AppleEvent *event , AppleEvent *reply)
 {
-       return noErr ;
+    return noErr ;
 }
 
 OSErr wxApp::MacHandleAEQuit(const AppleEvent *event , AppleEvent *reply)
 {
-       wxWindow* win = GetTopWindow() ;
-       if ( win )
-       {
-               win->Close(TRUE ) ;
-       }
-       else
-       {
-               ExitMainLoop() ;
-       }
-       return noErr ;
+    wxWindow* win = GetTopWindow() ;
+    if ( win )
+    {
+        win->Close(TRUE ) ;
+    }
+    else
+    {
+        ExitMainLoop() ;
+    }
+    return noErr ;
 }
 
-char StringMac[] =     "\x0d\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f"
-                                       "\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f"
-                                       "\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xae\xaf"
-                                       "\xb1\xb4\xb5\xb6\xbb\xbc\xbe\xbf"
-                                       "\xc0\xc1\xc2\xc4\xc7\xc8\xc9\xcb\xcc\xcd\xce\xcf"
-                                       "\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd8\xca\xdb" ;
+char StringMac[] =     "\x0d\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f"
+                    "\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f"
+                    "\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xae\xaf"
+                    "\xb1\xb4\xb5\xb6\xbb\xbc\xbe\xbf"
+                    "\xc0\xc1\xc2\xc4\xc7\xc8\xc9\xcb\xcc\xcd\xce\xcf"
+                    "\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd8\xca\xdb" ;
 
 char StringANSI[] = "\x0a\xC4\xC5\xC7\xC9\xD1\xD6\xDC\xE1\xE0\xE2\xE4\xE3\xE5\xE7\xE9\xE8"
-                                       "\xEA\xEB\xED\xEC\xEE\xEF\xF1\xF3\xF2\xF4\xF6\xF5\xFA\xF9\xFB\xFC"
-                                       "\x86\xBA\xA2\xA3\xA7\x95\xB6\xDF\xAE\xA9\x99\xB4\xA8\xC6\xD8"
-                                       "\xB1\xA5\xB5\xF0\xAA\xBA\xE6\xF8"
-                                       "\xBF\xA1\xAC\x83\xAB\xBB\x85\xC0\xC3\xD5\x8C\x9C"
-                                       "\x96\x97\x93\x94\x91\x92\xF7\xFF\xA0\x80" ;
+                    "\xEA\xEB\xED\xEC\xEE\xEF\xF1\xF3\xF2\xF4\xF6\xF5\xFA\xF9\xFB\xFC"
+                    "\x86\xBA\xA2\xA3\xA7\x95\xB6\xDF\xAE\xA9\x99\xB4\xA8\xC6\xD8"
+                    "\xB1\xA5\xB5\xF0\xAA\xBA\xE6\xF8"
+                    "\xBF\xA1\xAC\x83\xAB\xBB\x85\xC0\xC3\xD5\x8C\x9C"
+                    "\x96\x97\x93\x94\x91\x92\xF7\xFF\xA0\x80" ;
 
 void wxMacConvertFromPC( const char *from , char *to , int len )
 {
-       char *c ;
-       if ( from == to )
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringANSI , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringMac[ c - StringANSI] ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
-       else
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringANSI , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringMac[ c - StringANSI] ;
-                       }
-                       else
-                       {
-                               *to = *from ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
+    char *c ;
+    if ( from == to )
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringANSI , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringMac[ c - StringANSI] ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
+    else
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringANSI , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringMac[ c - StringANSI] ;
+            }
+            else
+            {
+                *to = *from ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
 }
 
 void wxMacConvertToPC( const char *from , char *to , int len )
 {
-       char *c ;
-       if ( from == to )
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringMac , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringANSI[ c - StringMac] ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
-       else
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringMac , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringANSI[ c - StringMac] ;
-                       }
-                       else
-                       {
-                               *to = *from ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
+    char *c ;
+    if ( from == to )
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringMac , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringANSI[ c - StringMac] ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
+    else
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringMac , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringANSI[ c - StringMac] ;
+            }
+            else
+            {
+                *to = *from ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
 }
 
 void wxMacConvertFromPC( char * p )
 {
-       char *ptr = p ;
-       int len = strlen ( p ) ;
+    char *ptr = p ;
+    int len = strlen ( p ) ;
 
-       wxMacConvertFromPC( ptr , ptr , len ) ;
+    wxMacConvertFromPC( ptr , ptr , len ) ;
 }
 
 void wxMacConvertFromPCForControls( char * p )
 {
-       char *ptr = p ;
-       int len = strlen ( p ) ;
-
-       wxMacConvertFromPC( ptr , ptr , len ) ;
-       for ( int i = 0 ; i < strlen ( ptr ) ; i++ )
-       {
-               if ( ptr[i] == '&' && ptr[i]+1 != ' ' )
-               {
-                       memmove( &ptr[i] , &ptr[i+1] , strlen( &ptr[i+1] ) + 1) ;
-               }
-       }
+    char *ptr = p ;
+    int len = strlen ( p ) ;
+
+    wxMacConvertFromPC( ptr , ptr , len ) ;
+    for ( int i = 0 ; i < strlen ( ptr ) ; i++ )
+    {
+        if ( ptr[i] == '&' && ptr[i]+1 != ' ' )
+        {
+            memmove( &ptr[i] , &ptr[i+1] , strlen( &ptr[i+1] ) + 1) ;
+        }
+    }
 }
 
 void wxMacConvertFromPC( unsigned char *p )
 {
-       char *ptr = (char*) p + 1 ;
-       int len = p[0] ;
+    char *ptr = (char*) p + 1 ;
+    int len = p[0] ;
 
-       wxMacConvertFromPC( ptr , ptr , len ) ;
+    wxMacConvertFromPC( ptr , ptr , len ) ;
 }
 
 extern char *wxBuffer ;
 
 wxString wxMacMakeMacStringFromPC( const char * p )
 {
-       const char *ptr = p ;
-       int len = strlen ( p ) ;
-       char *buf = wxBuffer ;
-
-       if ( len >= BUFSIZ + 512 )
-       {
-               buf = new char [len+1] ;
-       }
-
-       wxMacConvertFromPC( ptr , buf , len ) ;
-       buf[len] = 0 ;
-       wxString result( buf ) ;
-       if ( buf != wxBuffer )
-               delete buf ;
-       return result ;
+    const char *ptr = p ;
+    int len = strlen ( p ) ;
+    char *buf = wxBuffer ;
+
+    if ( len >= BUFSIZ + 512 )
+    {
+        buf = new char [len+1] ;
+    }
+
+    wxMacConvertFromPC( ptr , buf , len ) ;
+    buf[len] = 0 ;
+    wxString result( buf ) ;
+    if ( buf != wxBuffer )
+        delete buf ;
+    return result ;
 }
 
 
 void wxMacConvertToPC( char * p )
 {
-       char *ptr = p ;
-       int len = strlen ( p ) ;
+    char *ptr = p ;
+    int len = strlen ( p ) ;
 
-       wxMacConvertToPC( ptr , ptr , len ) ;
+    wxMacConvertToPC( ptr , ptr , len ) ;
 }
 
 void wxMacConvertToPC( unsigned char *p )
 {
-       char *ptr = (char*) p + 1 ;
-       int len = p[0] ;
+    char *ptr = (char*) p + 1 ;
+    int len = p[0] ;
 
-       wxMacConvertToPC( ptr , ptr , len ) ;
+    wxMacConvertToPC( ptr , ptr , len ) ;
 }
 
 wxString wxMacMakePCStringFromMac( const char * p )
 {
-       const char *ptr = p ;
-       int len = strlen ( p ) ;
-       char *buf = wxBuffer ;
-
-       if ( len >= BUFSIZ + 512 )
-       {
-               buf = new char [len+1] ;
-       }
-
-       wxMacConvertToPC( ptr , buf , len ) ;
-       buf[len] = 0 ;
-
-       wxString result( buf ) ;
-       if ( buf != wxBuffer )
-               delete buf ;
-       return result ;
+    const char *ptr = p ;
+    int len = strlen ( p ) ;
+    char *buf = wxBuffer ;
+
+    if ( len >= BUFSIZ + 512 )
+    {
+        buf = new char [len+1] ;
+    }
+
+    wxMacConvertToPC( ptr , buf , len ) ;
+    buf[len] = 0 ;
+
+    wxString result( buf ) ;
+    if ( buf != wxBuffer )
+        delete buf ;
+    return result ;
 }
 
-wxString wxMacMakeStringFromMacString( const char* from , bool mac2pcEncoding ) 
+wxString wxMacMakeStringFromMacString( const char* from , bool mac2pcEncoding )
 {
-       if (mac2pcEncoding)
-       {
-         return wxMacMakePCStringFromMac( from ) ;
-       }
-       else
-       {
-         return wxString( from ) ;
-       }
+    if (mac2pcEncoding)
+    {
+      return wxMacMakePCStringFromMac( from ) ;
+    }
+    else
+    {
+      return wxString( from ) ;
+    }
 }
 
-wxString wxMacMakeStringFromPascal( StringPtr from , bool mac2pcEncoding ) 
+wxString wxMacMakeStringFromPascal( StringPtr from , bool mac2pcEncoding )
 {
   // this is safe since a pascal string can never be larger than 256 bytes
   char s[256] ;
   CopyPascalStringToC( from , s ) ;
-       if (mac2pcEncoding)
-       {
-         return wxMacMakePCStringFromMac( s ) ;
-       }
-       else
-       {
-         return wxString( s ) ;
-       }
+    if (mac2pcEncoding)
+    {
+      return wxMacMakePCStringFromMac( s ) ;
+    }
+    else
+    {
+      return wxString( s ) ;
+    }
 }
 
-void wxMacStringToPascal( const char * from , StringPtr to , bool pc2macEncoding ) 
+void wxMacStringToPascal( const char * from , StringPtr to , bool pc2macEncoding )
 {
-       if (pc2macEncoding)
-       {
-         CopyCStringToPascal( wxMacMakeMacStringFromPC( from ) , to ) ;
-       }
-       else
-       {
-         CopyCStringToPascal( from , to ) ;
-       }
+    if (pc2macEncoding)
+    {
+      CopyCStringToPascal( wxMacMakeMacStringFromPC( from ) , to ) ;
+    }
+    else
+    {
+      CopyCStringToPascal( from , to ) ;
+    }
 }
 
 bool wxApp::Initialize()
@@ -388,7 +388,7 @@ bool wxApp::Initialize()
 
   UMAInitToolbox( 4 ) ;
   SetEventMask( everyEvent ) ;
-       UMAShowWatchCursor() ;
+    UMAShowWatchCursor() ;
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
     AEInstallEventHandler( kCoreEventClass , kAEOpenDocuments ,   NewAEEventHandlerUPP(AEHandleODoc) ,
@@ -400,73 +400,73 @@ bool wxApp::Initialize()
     AEInstallEventHandler( kCoreEventClass , kAEQuitApplication , NewAEEventHandlerUPP(AEHandleQuit) ,
                            (long) wxTheApp , FALSE ) ;
 #else
-       AEInstallEventHandler( kCoreEventClass , kAEOpenDocuments ,   NewAEEventHandlerProc(AEHandleODoc) ,
-                              (long) wxTheApp , FALSE ) ;
-       AEInstallEventHandler( kCoreEventClass , kAEOpenApplication , NewAEEventHandlerProc(AEHandleOApp) ,
-                              (long) wxTheApp , FALSE ) ;
-       AEInstallEventHandler( kCoreEventClass , kAEPrintDocuments ,  NewAEEventHandlerProc(AEHandlePDoc) ,
-                              (long) wxTheApp , FALSE ) ;
-       AEInstallEventHandler( kCoreEventClass , kAEQuitApplication , NewAEEventHandlerProc(AEHandleQuit) ,
-                              (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEOpenDocuments ,   NewAEEventHandlerProc(AEHandleODoc) ,
+                   (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEOpenApplication , NewAEEventHandlerProc(AEHandleOApp) ,
+                   (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEPrintDocuments ,  NewAEEventHandlerProc(AEHandlePDoc) ,
+                   (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEQuitApplication , NewAEEventHandlerProc(AEHandleQuit) ,
+                   (long) wxTheApp , FALSE ) ;
 #endif
 
 
 #ifndef __DARWIN__
   // test the minimal configuration necessary
 
-       #if !TARGET_CARBON
-       long theSystem ;
-       long theMachine; 
-
-       if (Gestalt(gestaltMachineType, &theMachine) != noErr)
-       {
-               error = kMacSTRWrongMachine;
-       }
-       else if (theMachine < gestaltMacPlus)
-       {
-               error = kMacSTRWrongMachine;
-       }
-       else if (Gestalt(gestaltSystemVersion, &theSystem) != noErr )
-       {
-               error = kMacSTROldSystem  ;
-       }
-       else if ( theSystem < 0x0750 )
-       {
-               error = kMacSTROldSystem  ;
-       }
-       else if ((long)GetApplLimit() - (long)ApplicationZone() < kMacMinHeap)
-       {
-               error = kMacSTRSmallSize;
-       }
-       #endif
-       /*
-       else
-       {
-               if ( !UMAHasAppearance() )
-               {
-                       error = kMacSTRNoPre8Yet ;
-               }
-       }
-       */
+    #if !TARGET_CARBON
+    long theSystem ;
+    long theMachine;
+
+    if (Gestalt(gestaltMachineType, &theMachine) != noErr)
+    {
+        error = kMacSTRWrongMachine;
+    }
+    else if (theMachine < gestaltMacPlus)
+    {
+        error = kMacSTRWrongMachine;
+    }
+    else if (Gestalt(gestaltSystemVersion, &theSystem) != noErr )
+    {
+        error = kMacSTROldSystem  ;
+    }
+    else if ( theSystem < 0x0750 )
+    {
+        error = kMacSTROldSystem  ;
+    }
+    else if ((long)GetApplLimit() - (long)ApplicationZone() < kMacMinHeap)
+    {
+        error = kMacSTRSmallSize;
+    }
+    #endif
+    /*
+    else
+    {
+        if ( !UMAHasAppearance() )
+        {
+            error = kMacSTRNoPre8Yet ;
+        }
+    }
+    */
 #endif
 
-       // if we encountered any problems so far, give the error code and exit immediately
+    // if we encountered any problems so far, give the error code and exit immediately
 
   if ( error )
   {
-               short itemHit;
-               Str255 message;
-
-               GetIndString(message, 128, error);
-               UMAShowArrowCursor() ;
-               ParamText("\pFatal Error", message, (ConstStr255Param)"\p", (ConstStr255Param)"\p");
-               itemHit = Alert(128, nil);
-         return FALSE ;
+        short itemHit;
+        Str255 message;
+
+        GetIndString(message, 128, error);
+        UMAShowArrowCursor() ;
+        ParamText("\pFatal Error", message, (ConstStr255Param)"\p", (ConstStr255Param)"\p");
+        itemHit = Alert(128, nil);
+      return FALSE ;
   }
 
 #ifndef __DARWIN__
   #if __option(profile)
-       ProfilerInit( collectDetailed, bestTimeBase , 20000 , 40 ) ;
+    ProfilerInit( collectDetailed, bestTimeBase , 20000 , 40 ) ;
   #endif
 #endif
 
@@ -476,7 +476,7 @@ bool wxApp::Initialize()
   std::__throws_bad_alloc = FALSE ;
 #endif
 
-       s_macCursorRgn = ::NewRgn() ;
+    s_macCursorRgn = ::NewRgn() ;
 
 #ifdef __WXMSW__
   wxBuffer = new char[1500];
@@ -529,7 +529,7 @@ bool wxApp::Initialize()
   wxMacCreateNotifierTable() ;
 
   UMAShowArrowCursor() ;
-  
+
   return TRUE;
 }
 
@@ -610,13 +610,13 @@ void wxApp::CleanUp()
     delete wxLog::SetActiveTarget(NULL);
 #endif // wxUSE_LOG
 
-       UMACleanupToolbox() ;
-       if (s_macCursorRgn)
-               ::DisposeRgn(s_macCursorRgn);
+    UMACleanupToolbox() ;
+    if (s_macCursorRgn)
+        ::DisposeRgn(s_macCursorRgn);
 
-       #if 0
-               TerminateAE() ;
-       #endif
+    #if 0
+        TerminateAE() ;
+    #endif
 }
 
 int wxEntry( int argc, char *argv[] , bool enterLoop )
@@ -668,40 +668,40 @@ int wxEntry( int argc, char *argv[] , bool enterLoop )
 
   int retValue = 0;
 
-       if ( wxTheApp->OnInit() )
-       {
-           if ( enterLoop )
-           {
-               retValue = wxTheApp->OnRun();
-           }
-           else
-               // We want to initialize, but not run or exit immediately.
-               return 1;
-       }
-       //else: app initialization failed, so we skipped OnRun()
-
-       wxWindow *topWindow = wxTheApp->GetTopWindow();
-       if ( topWindow )
-       {
-           // Forcibly delete the window.
-           if ( topWindow->IsKindOf(CLASSINFO(wxFrame)) ||
-                   topWindow->IsKindOf(CLASSINFO(wxDialog)) )
-           {
-               topWindow->Close(TRUE);
-               wxTheApp->DeletePendingObjects();
-           }
-           else
-           {
-               delete topWindow;
-               wxTheApp->SetTopWindow(NULL);
-           }
-       }
-       
-       wxTheApp->OnExit();
-       
-       wxApp::CleanUp();
-       
-       return retValue;
+    if ( wxTheApp->OnInit() )
+    {
+        if ( enterLoop )
+        {
+            retValue = wxTheApp->OnRun();
+        }
+        else
+            // We want to initialize, but not run or exit immediately.
+            return 1;
+    }
+    //else: app initialization failed, so we skipped OnRun()
+
+    wxWindow *topWindow = wxTheApp->GetTopWindow();
+    if ( topWindow )
+    {
+        // Forcibly delete the window.
+        if ( topWindow->IsKindOf(CLASSINFO(wxFrame)) ||
+                topWindow->IsKindOf(CLASSINFO(wxDialog)) )
+        {
+            topWindow->Close(TRUE);
+            wxTheApp->DeletePendingObjects();
+        }
+        else
+        {
+            delete topWindow;
+            wxTheApp->SetTopWindow(NULL);
+        }
+    }
+
+    wxTheApp->OnExit();
+
+    wxApp::CleanUp();
+
+    return retValue;
 }
 
 // Static member initialization
@@ -736,7 +736,7 @@ int wxApp::MainLoop()
 
   while (m_keepGoing)
   {
-               MacDoOneEvent() ;
+        MacDoOneEvent() ;
   }
 
   return 0;
@@ -760,7 +760,7 @@ void wxApp::ExitMainLoop()
 // Is a message/event pending?
 bool wxApp::Pending()
 {
-       EventRecord event ;
+    EventRecord event ;
 
   return EventAvail( everyEvent , &event ) ;
 }
@@ -768,7 +768,7 @@ bool wxApp::Pending()
 // Dispatch a message.
 void wxApp::Dispatch()
 {
-       MacDoOneEvent() ;
+    MacDoOneEvent() ;
 }
 
 void wxApp::OnIdle(wxIdleEvent& event)
@@ -806,22 +806,22 @@ void wxApp::OnIdle(wxIdleEvent& event)
 
 void wxWakeUpIdle()
 {
-       wxMacWakeUp() ;
+    wxMacWakeUp() ;
 }
 
 // Send idle event to all top-level windows
 bool wxApp::SendIdleEvents()
 {
     bool needMore = FALSE;
-       wxNode* node = wxTopLevelWindows.First();
-       while (node)
-       {
-               wxWindow* win = (wxWindow*) node->Data();
-               if (SendIdleEvents(win))
+    wxNode* node = wxTopLevelWindows.First();
+    while (node)
+    {
+        wxWindow* win = (wxWindow*) node->Data();
+        if (SendIdleEvents(win))
             needMore = TRUE;
 
-               node = node->Next();
-       }
+        node = node->Next();
+    }
     return needMore;
 }
 
@@ -830,22 +830,22 @@ bool wxApp::SendIdleEvents(wxWindow* win)
 {
     bool needMore = FALSE;
 
-       wxIdleEvent event;
-       event.SetEventObject(win);
-       win->ProcessEvent(event);
+    wxIdleEvent event;
+    event.SetEventObject(win);
+    win->ProcessEvent(event);
 
     if (event.MoreRequested())
         needMore = TRUE;
 
-       wxNode* node = win->GetChildren().First();
-       while (node)
-       {
-               wxWindow* win = (wxWindow*) node->Data();
-               if (SendIdleEvents(win))
+    wxNode* node = win->GetChildren().First();
+    while (node)
+    {
+        wxWindow* win = (wxWindow*) node->Data();
+        if (SendIdleEvents(win))
             needMore = TRUE;
 
-               node = node->Next();
-       }
+        node = node->Next();
+    }
     return needMore ;
 }
 
@@ -895,7 +895,7 @@ void wxExit()
     wxLogError(_("Fatal error: exiting"));
 
     wxApp::CleanUp();
-       ::ExitToShell() ;
+    ::ExitToShell() ;
 }
 
 void wxApp::OnEndSession(wxCloseEvent& WXUNUSED(event))
@@ -918,80 +918,76 @@ void wxApp::OnQueryEndSession(wxCloseEvent& event)
 extern "C" void wxCYield() ;
 void wxCYield()
 {
-       wxYield() ;
+    wxYield() ;
 }
 
 // Yield to other processes
 
-static bool gs_inYield = FALSE;
-
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
-#ifdef __WXDEBUG__    
-    if (gs_inYield)
-        wxFAIL_MSG( wxT("wxYield called recursively" ) );
-#endif
+    static bool s_inYield = FALSE;
+
+    if (s_inYield)
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( wxT("wxYield called recursively" ) );
+        }
+
+        return FALSE;
+    }
+
+    s_inYield = TRUE;
 
-    gs_inYield = TRUE;
-    
 #if wxUSE_THREADS
     YieldToAnyThread() ;
 #endif
     EventRecord event ;
 
-       long sleepTime = 1 ; //::GetCaretTime();
+    long sleepTime = 1 ; //::GetCaretTime();
 
-       while ( !wxTheApp->IsExiting() && WaitNextEvent(everyEvent, &event,sleepTime, wxApp::s_macCursorRgn))
-       {
-       wxTheApp->MacHandleOneEvent( &event );
-           if ( event.what != kHighLevelEvent )
-                   SetRectRgn( wxApp::s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
-       }
+    while ( !wxTheApp->IsExiting() && WaitNextEvent(everyEvent, &event,sleepTime, wxApp::s_macCursorRgn))
+    {
+        wxTheApp->MacHandleOneEvent( &event );
+        if ( event.what != kHighLevelEvent )
+            SetRectRgn( wxApp::s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
+    }
 
-       wxMacProcessNotifierAndPendingEvents() ;
+    wxMacProcessNotifierAndPendingEvents() ;
 
-    gs_inYield = FALSE;
-    
-    return TRUE;
-}
+    s_inYield = FALSE;
 
-// Yield to incoming messages; but fail silently if recursion is detected.
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-        
-    return wxYield();
+    return TRUE;
 }
 
 // platform specifics
 
 void wxApp::MacSuspend( bool convertClipboard )
 {
-       // we have to deactive the window manually
-       
-       wxWindow* window = GetTopWindow() ;
-       if ( window )
-               window->MacActivate( MacGetCurrentEvent() , false ) ;
-               
-               s_lastMouseDown = 0 ;
-               if( convertClipboard )
-               {
-                       MacConvertPrivateToPublicScrap() ;
-               }
-
-               UMAHideFloatingWindows() ;
+    // we have to deactive the window manually
+
+    wxWindow* window = GetTopWindow() ;
+    if ( window )
+        window->MacActivate( MacGetCurrentEvent() , false ) ;
+
+        s_lastMouseDown = 0 ;
+        if( convertClipboard )
+        {
+            MacConvertPrivateToPublicScrap() ;
+        }
+
+        UMAHideFloatingWindows() ;
 }
 
 void wxApp::MacResume( bool convertClipboard )
 {
-               s_lastMouseDown = 0 ;
-               if( convertClipboard )
-               {
-                       MacConvertPublicToPrivateScrap() ;
-               }
+        s_lastMouseDown = 0 ;
+        if( convertClipboard )
+        {
+            MacConvertPublicToPrivateScrap() ;
+        }
 
-               UMAShowFloatingWindows() ;
+        UMAShowFloatingWindows() ;
 }
 
 void wxApp::MacConvertPrivateToPublicScrap()
@@ -1006,723 +1002,723 @@ void wxApp::MacDoOneEvent()
 {
   EventRecord event ;
 
-       long sleepTime = 1 ; // GetCaretTime() / 4 ;
+    long sleepTime = 1 ; // GetCaretTime() / 4 ;
 
-       if (WaitNextEvent(everyEvent, &event,sleepTime, s_macCursorRgn))
-       {
+    if (WaitNextEvent(everyEvent, &event,sleepTime, s_macCursorRgn))
+    {
     MacHandleOneEvent( &event );
-       }
-       else
-       {
-               // idlers
-               WindowPtr window = UMAFrontWindow() ;
-               if ( window )
-                       UMAIdleControls( window ) ;
+    }
+    else
+    {
+        // idlers
+        WindowPtr window = UMAFrontWindow() ;
+        if ( window )
+            UMAIdleControls( window ) ;
 
-               wxTheApp->ProcessIdle() ;
-       }
-       if ( event.what != kHighLevelEvent )
-               SetRectRgn( s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
+        wxTheApp->ProcessIdle() ;
+    }
+    if ( event.what != kHighLevelEvent )
+        SetRectRgn( s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
 
-       // repeaters
+    // repeaters
 
   DeletePendingObjects() ;
-       wxMacProcessNotifierAndPendingEvents() ;
+    wxMacProcessNotifierAndPendingEvents() ;
 }
 
 void wxApp::MacHandleOneEvent( EventRecord *ev )
 {
-       m_macCurrentEvent = ev ;
-
-       wxApp::sm_lastMessageTime = ev->when ;
-
-       switch (ev->what)
-       {
-               case mouseDown:
-                       MacHandleMouseDownEvent( ev ) ;
-                       if ( ev->modifiers & controlKey )
-                               s_lastMouseDown = 2;
-                       else
-                               s_lastMouseDown = 1;
-                       break;
-               case mouseUp:
-                       if ( s_lastMouseDown == 2 )
-                       {
-                               ev->modifiers |= controlKey ;
-                       }
-                       else
-                       {
-                               ev->modifiers &= ~controlKey ;
-                       }
-                       MacHandleMouseUpEvent( ev ) ;
-                       s_lastMouseDown = 0;
-                       break;
-               case activateEvt:
-                       MacHandleActivateEvent( ev ) ;
-                       break;
-               case updateEvt:
-                       MacHandleUpdateEvent( ev ) ;
-                       break;
-               case keyDown:
-               case autoKey:
-                       MacHandleKeyDownEvent( ev ) ;
-                       break;
-               case keyUp:
-                       MacHandleKeyUpEvent( ev ) ;
-                       break;
-               case diskEvt:
-                       MacHandleDiskEvent( ev ) ;
-                       break;
-               case osEvt:
-                       MacHandleOSEvent( ev ) ;
-                       break;
-               case kHighLevelEvent:
-                       MacHandleHighLevelEvent( ev ) ;
-                       break;
-               default:
-                       break;
-       }
-       wxMacProcessNotifierAndPendingEvents() ;
+    m_macCurrentEvent = ev ;
+
+    wxApp::sm_lastMessageTime = ev->when ;
+
+    switch (ev->what)
+    {
+        case mouseDown:
+            MacHandleMouseDownEvent( ev ) ;
+            if ( ev->modifiers & controlKey )
+                s_lastMouseDown = 2;
+            else
+                s_lastMouseDown = 1;
+            break;
+        case mouseUp:
+            if ( s_lastMouseDown == 2 )
+            {
+                ev->modifiers |= controlKey ;
+            }
+            else
+            {
+                ev->modifiers &= ~controlKey ;
+            }
+            MacHandleMouseUpEvent( ev ) ;
+            s_lastMouseDown = 0;
+            break;
+        case activateEvt:
+            MacHandleActivateEvent( ev ) ;
+            break;
+        case updateEvt:
+            MacHandleUpdateEvent( ev ) ;
+            break;
+        case keyDown:
+        case autoKey:
+            MacHandleKeyDownEvent( ev ) ;
+            break;
+        case keyUp:
+            MacHandleKeyUpEvent( ev ) ;
+            break;
+        case diskEvt:
+            MacHandleDiskEvent( ev ) ;
+            break;
+        case osEvt:
+            MacHandleOSEvent( ev ) ;
+            break;
+        case kHighLevelEvent:
+            MacHandleHighLevelEvent( ev ) ;
+            break;
+        default:
+            break;
+    }
+    wxMacProcessNotifierAndPendingEvents() ;
 }
 
 void wxApp::MacHandleHighLevelEvent( EventRecord *ev )
 {
-       ::AEProcessAppleEvent( ev ) ;
+    ::AEProcessAppleEvent( ev ) ;
 }
 
 bool s_macIsInModalLoop = false ;
 
 void wxApp::MacHandleMouseDownEvent( EventRecord *ev )
 {
-       wxToolTip::RemoveToolTips() ;
+    wxToolTip::RemoveToolTips() ;
 
-       WindowRef window;
-       WindowRef frontWindow = UMAFrontNonFloatingWindow() ;
-       WindowAttributes frontWindowAttributes = NULL ;
-       if ( frontWindow )
-               UMAGetWindowAttributes( frontWindow , &frontWindowAttributes ) ;
+    WindowRef window;
+    WindowRef frontWindow = UMAFrontNonFloatingWindow() ;
+    WindowAttributes frontWindowAttributes = NULL ;
+    if ( frontWindow )
+        UMAGetWindowAttributes( frontWindow , &frontWindowAttributes ) ;
 
-       short windowPart = ::FindWindow(ev->where, &window);
-       wxWindow* win = wxFindWinFromMacWindow( window ) ;
+    short windowPart = ::FindWindow(ev->where, &window);
+    wxWindow* win = wxFindWinFromMacWindow( window ) ;
     if ( wxPendingDelete.Member(win) )
         return ;
 
-       BitMap screenBits;
-       GetQDGlobalsScreenBits( &screenBits );
-
-       switch (windowPart)
-       {
-               case inMenuBar :
-                       if ( s_macIsInModalLoop )
-                       {
-                               SysBeep ( 30 ) ;
-                       }
-                       else
-                       {
-                               UInt32 menuresult = MenuSelect(ev->where) ;
-                               MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) );
-                               s_lastMouseDown = 0;
-                       }
-                       break ;
+    BitMap screenBits;
+    GetQDGlobalsScreenBits( &screenBits );
+
+    switch (windowPart)
+    {
+        case inMenuBar :
+            if ( s_macIsInModalLoop )
+            {
+                SysBeep ( 30 ) ;
+            }
+            else
+            {
+                UInt32 menuresult = MenuSelect(ev->where) ;
+                MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) );
+                s_lastMouseDown = 0;
+            }
+            break ;
 #if !TARGET_CARBON
-               case inSysWindow :
-                       SystemClick( ev , window ) ;
-                       s_lastMouseDown = 0;
-                       break ;
+        case inSysWindow :
+            SystemClick( ev , window ) ;
+            s_lastMouseDown = 0;
+            break ;
 #endif
-               case inDrag :
-                       if ( window != frontWindow && s_macIsInModalLoop && !(ev->modifiers & cmdKey ) )
-                       {
-                               SysBeep ( 30 ) ;
-                       }
-                       else
-                       {
-                               DragWindow(window, ev->where, &screenBits.bounds);
-                               if (win)
-                               {
-                                       GrafPtr port ;
-                                       GetPort( &port ) ;
-                                       Point pt = { 0, 0 } ;
-                                       #if TARGET_CARBON
-                                       SetPort( GetWindowPort(window) ) ;
-                                       #else
-                                       SetPort( (window) ) ;
-                                       #endif
-                                       SetOrigin( 0 , 0 ) ;
-                                       LocalToGlobal( &pt ) ;
-                                       SetPort( port ) ;
-                                               win->SetSize( pt.h , pt.v , -1 ,
-                                                       -1 , wxSIZE_USE_EXISTING);
-                               }
-                               s_lastMouseDown = 0;
-                       }
-                       break ;
-               case inGoAway:
-                       if (TrackGoAway(window, ev->where))
-                       {
-                               if ( win )
-                                       win->Close() ;
-                       }
-                       s_lastMouseDown = 0;
-                       break;
-               case inGrow:
-                 {
-                               int growResult = GrowWindow(window , ev->where, &screenBits.bounds);
-                               if (growResult != 0)
-                               {
-                                       int newWidth = LoWord(growResult);
-                                       int newHeight = HiWord(growResult);
-                                       int oldWidth, oldHeight;
-
-
-                                       if (win)
-                                       {
-                                               win->GetSize(&oldWidth, &oldHeight);
-                                               if (newWidth == 0)
-                                                       newWidth = oldWidth;
-                                               if (newHeight == 0)
-                                                       newHeight = oldHeight;
-                                               win->SetSize( -1, -1, newWidth, newHeight, wxSIZE_USE_EXISTING);
-                                       }
-                               }
-                               s_lastMouseDown = 0;
-                 }
-                       break;
-               case inZoomIn:
-               case inZoomOut:
-                               if (TrackBox(window, ev->where, windowPart))
-                               {
-                                       // TODO setup size event
-                                       ZoomWindow( window , windowPart , false ) ;
-                                       if (win)
-                                       {
-                                               Rect tempRect ;
-                                               
-                                               GetWindowPortBounds(window, &tempRect ) ;
-                                               win->SetSize( -1, -1, tempRect.right-tempRect.left ,
-                                                       tempRect.bottom-tempRect.top, wxSIZE_USE_EXISTING);
-                                       }
-                               }
-                       s_lastMouseDown = 0;
-                       break;
-               case inCollapseBox :
-                               // TODO setup size event
-                       s_lastMouseDown = 0;
-                       break ;
-
-               case inContent :
-                               {
-                                       GrafPtr port ;
-                                       GetPort( &port ) ;
-                                       #if TARGET_CARBON
-                                       SetPort( GetWindowPort(window) ) ;
-                                       #else
-                                       SetPort( (window) ) ;
-                                       #endif
-                                       SetOrigin( 0 , 0 ) ;
-                                       SetPort( port ) ;
-                               }
-                               if ( window != frontWindow && wxTheApp->s_captureWindow == NULL )
-                               {
-                                       if ( s_macIsInModalLoop )
-                                       {
-                                               SysBeep ( 30 ) ;
-                                       }
-                                       else if ( UMAIsWindowFloating( window ) )
-                                       {
-                                               if ( win )
-                                                       win->MacMouseDown( ev , windowPart ) ;
-                                       }
-                                       else
-                                       {
-                                               if ( win )
-                                                       win->MacMouseDown( ev , windowPart ) ;
-                                               UMASelectWindow( window ) ;
-                                       }
-                               }
-                               else
-                               {
-                                       if ( win )
-                                               win->MacMouseDown( ev , windowPart ) ;
-                               }
-                       break ;
-
-               default:
-                       break;
-       }
+        case inDrag :
+            if ( window != frontWindow && s_macIsInModalLoop && !(ev->modifiers & cmdKey ) )
+            {
+                SysBeep ( 30 ) ;
+            }
+            else
+            {
+                DragWindow(window, ev->where, &screenBits.bounds);
+                if (win)
+                {
+                    GrafPtr port ;
+                    GetPort( &port ) ;
+                    Point pt = { 0, 0 } ;
+                    #if TARGET_CARBON
+                    SetPort( GetWindowPort(window) ) ;
+                    #else
+                    SetPort( (window) ) ;
+                    #endif
+                    SetOrigin( 0 , 0 ) ;
+                    LocalToGlobal( &pt ) ;
+                    SetPort( port ) ;
+                        win->SetSize( pt.h , pt.v , -1 ,
+                            -1 , wxSIZE_USE_EXISTING);
+                }
+                s_lastMouseDown = 0;
+            }
+            break ;
+        case inGoAway:
+            if (TrackGoAway(window, ev->where))
+            {
+                if ( win )
+                    win->Close() ;
+            }
+            s_lastMouseDown = 0;
+            break;
+        case inGrow:
+          {
+                int growResult = GrowWindow(window , ev->where, &screenBits.bounds);
+                if (growResult != 0)
+                {
+                    int newWidth = LoWord(growResult);
+                    int newHeight = HiWord(growResult);
+                    int oldWidth, oldHeight;
+
+
+                    if (win)
+                    {
+                        win->GetSize(&oldWidth, &oldHeight);
+                        if (newWidth == 0)
+                            newWidth = oldWidth;
+                        if (newHeight == 0)
+                            newHeight = oldHeight;
+                        win->SetSize( -1, -1, newWidth, newHeight, wxSIZE_USE_EXISTING);
+                    }
+                }
+                s_lastMouseDown = 0;
+          }
+            break;
+        case inZoomIn:
+        case inZoomOut:
+                if (TrackBox(window, ev->where, windowPart))
+                {
+                    // TODO setup size event
+                    ZoomWindow( window , windowPart , false ) ;
+                    if (win)
+                    {
+                        Rect tempRect ;
+
+                        GetWindowPortBounds(window, &tempRect ) ;
+                        win->SetSize( -1, -1, tempRect.right-tempRect.left ,
+                            tempRect.bottom-tempRect.top, wxSIZE_USE_EXISTING);
+                    }
+                }
+            s_lastMouseDown = 0;
+            break;
+        case inCollapseBox :
+                // TODO setup size event
+            s_lastMouseDown = 0;
+            break ;
+
+        case inContent :
+                {
+                    GrafPtr port ;
+                    GetPort( &port ) ;
+                    #if TARGET_CARBON
+                    SetPort( GetWindowPort(window) ) ;
+                    #else
+                    SetPort( (window) ) ;
+                    #endif
+                    SetOrigin( 0 , 0 ) ;
+                    SetPort( port ) ;
+                }
+                if ( window != frontWindow && wxTheApp->s_captureWindow == NULL )
+                {
+                    if ( s_macIsInModalLoop )
+                    {
+                        SysBeep ( 30 ) ;
+                    }
+                    else if ( UMAIsWindowFloating( window ) )
+                    {
+                        if ( win )
+                            win->MacMouseDown( ev , windowPart ) ;
+                    }
+                    else
+                    {
+                        if ( win )
+                            win->MacMouseDown( ev , windowPart ) ;
+                        UMASelectWindow( window ) ;
+                    }
+                }
+                else
+                {
+                    if ( win )
+                        win->MacMouseDown( ev , windowPart ) ;
+                }
+            break ;
+
+        default:
+            break;
+    }
 }
 
 void wxApp::MacHandleMouseUpEvent( EventRecord *ev )
 {
-       WindowRef window;
-
-       short windowPart = ::FindWindow(ev->where, &window);
-
-       switch (windowPart)
-       {
-               case inMenuBar :
-                       break ;
-               case inSysWindow :
-                       break ;
-               default:
-                       {
-                               wxWindow* win = wxFindWinFromMacWindow( window ) ;
-                               if ( win )
-                                       win->MacMouseUp( ev , windowPart ) ;
-                       }
-                       break;
-       }
+    WindowRef window;
+
+    short windowPart = ::FindWindow(ev->where, &window);
+
+    switch (windowPart)
+    {
+        case inMenuBar :
+            break ;
+        case inSysWindow :
+            break ;
+        default:
+            {
+                wxWindow* win = wxFindWinFromMacWindow( window ) ;
+                if ( win )
+                    win->MacMouseUp( ev , windowPart ) ;
+            }
+            break;
+    }
 }
 
 long wxMacTranslateKey(unsigned char key, unsigned char code)
 {
-       long retval = key ;
+    long retval = key ;
     switch (key)
     {
-       case 0x01 :
-                               retval = WXK_HOME;
-                 break;
-       case 0x03 :
-                               retval = WXK_RETURN;
-                 break;
-       case 0x04 :
-                               retval = WXK_END;
-                 break;
-       case 0x05 :
-                               retval = WXK_HELP;
-                 break;
-       case 0x08 :
-                               retval = WXK_BACK;
-                 break;
-       case 0x09 :
-                               retval = WXK_TAB;
-                 break;
-       case 0x0b :
-                               retval = WXK_PAGEUP;
-                 break;
-       case 0x0c :
-                               retval = WXK_PAGEDOWN;
-                 break;
-       case 0x0d :
-                               retval = WXK_RETURN;
-                 break;
-                       case 0x10 :
-                       {
-                               switch( code )
-                               {
-                                       case 0x7a :
-                                               retval = WXK_F1 ;
-                                               break;
-                                       case 0x78 :
-                                               retval = WXK_F2 ;
-                                               break;
-                                       case 0x63 :
-                                               retval = WXK_F3 ;
-                                               break;
-                                       case 0x76 :
-                                               retval = WXK_F4 ;
-                                               break;
-                                       case 0x60 :
-                                               retval = WXK_F5 ;
-                                               break;
-                                       case 0x61 :
-                                               retval = WXK_F6 ;
-                                               break;
-                                       case 0x62:
-                                               retval = WXK_F7 ;
-                                               break;
-                                       case 0x64 :
-                                               retval = WXK_F8 ;
-                                               break;
-                                       case 0x65 :
-                                               retval = WXK_F9 ;
-                                               break;
-                                       case 0x6D :
-                                               retval = WXK_F10 ;
-                                               break;
-                                       case 0x67 :
-                                               retval = WXK_F11 ;
-                                               break;
-                                       case 0x6F :
-                                               retval = WXK_F12 ;
-                                               break;
-                                       case 0x69 :
-                                               retval = WXK_F13 ;
-                                               break;
-                                       case 0x6B :
-                                               retval = WXK_F14 ;
-                                               break;
-                                       case 0x71 :
-                                               retval = WXK_F15 ;
-                                               break;
-                               }
-                       }
-                       break ;
-                       case 0x1b :
-                               retval = WXK_ESCAPE ;
-                       break ;
-                       case 0x1c :
-                               retval = WXK_LEFT ;
-                       break ;
-                       case 0x1d :
-                               retval = WXK_RIGHT ;
-                       break ;
-                       case 0x1e :
-                               retval = WXK_UP ;
-                       break ;
-                       case 0x1f :
-                               retval = WXK_DOWN ;
-                       break ;
-                       case 0x7F :
-                               retval = WXK_DELETE ;
-                       default:
-                       break ;
-       } // end switch
-
-       return retval;
+        case 0x01 :
+                 retval = WXK_HOME;
+          break;
+        case 0x03 :
+                 retval = WXK_RETURN;
+          break;
+        case 0x04 :
+                 retval = WXK_END;
+          break;
+        case 0x05 :
+                 retval = WXK_HELP;
+          break;
+        case 0x08 :
+                 retval = WXK_BACK;
+          break;
+        case 0x09 :
+                 retval = WXK_TAB;
+          break;
+        case 0x0b :
+                 retval = WXK_PAGEUP;
+          break;
+        case 0x0c :
+                 retval = WXK_PAGEDOWN;
+          break;
+        case 0x0d :
+                 retval = WXK_RETURN;
+          break;
+            case 0x10 :
+            {
+                switch( code )
+                {
+                    case 0x7a :
+                        retval = WXK_F1 ;
+                        break;
+                    case 0x78 :
+                        retval = WXK_F2 ;
+                        break;
+                    case 0x63 :
+                        retval = WXK_F3 ;
+                        break;
+                    case 0x76 :
+                        retval = WXK_F4 ;
+                        break;
+                    case 0x60 :
+                        retval = WXK_F5 ;
+                        break;
+                    case 0x61 :
+                        retval = WXK_F6 ;
+                        break;
+                    case 0x62:
+                        retval = WXK_F7 ;
+                        break;
+                    case 0x64 :
+                        retval = WXK_F8 ;
+                        break;
+                    case 0x65 :
+                        retval = WXK_F9 ;
+                        break;
+                    case 0x6D :
+                        retval = WXK_F10 ;
+                        break;
+                    case 0x67 :
+                        retval = WXK_F11 ;
+                        break;
+                    case 0x6F :
+                        retval = WXK_F12 ;
+                        break;
+                    case 0x69 :
+                        retval = WXK_F13 ;
+                        break;
+                    case 0x6B :
+                        retval = WXK_F14 ;
+                        break;
+                    case 0x71 :
+                        retval = WXK_F15 ;
+                        break;
+                }
+            }
+            break ;
+            case 0x1b :
+                retval = WXK_ESCAPE ;
+            break ;
+            case 0x1c :
+                retval = WXK_LEFT ;
+            break ;
+            case 0x1d :
+                retval = WXK_RIGHT ;
+            break ;
+            case 0x1e :
+                retval = WXK_UP ;
+            break ;
+            case 0x1f :
+                retval = WXK_DOWN ;
+            break ;
+            case 0x7F :
+                retval = WXK_DELETE ;
+             default:
+            break ;
+     } // end switch
+
+    return retval;
 }
 
 void wxApp::MacHandleKeyDownEvent( EventRecord *ev )
 {
-       wxToolTip::RemoveToolTips() ;
-       
-       UInt32 menuresult = UMAMenuEvent(ev) ;
-       if ( HiWord( menuresult ) )
-       {
-               if ( !s_macIsInModalLoop )
-               MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) ) ;
-       }
-       else
-       {
-               short keycode ;
-               short keychar ;
-               keychar = short(ev->message & charCodeMask);
-               keycode = short(ev->message & keyCodeMask) >> 8 ;
-
-               wxWindow* focus = wxWindow::FindFocus() ;
-               if ( focus )
-               {
-                       long keyval = wxMacTranslateKey(keychar, keycode) ;
-                       
-                       wxKeyEvent event(wxEVT_KEY_DOWN);
-                       event.m_shiftDown = ev->modifiers & shiftKey;
-                       event.m_controlDown = ev->modifiers & controlKey;
-                       event.m_altDown = ev->modifiers & optionKey;
-                       event.m_metaDown = ev->modifiers & cmdKey;
-                       event.m_keyCode = keyval;
-                       event.m_x = ev->where.h;
-                       event.m_y = ev->where.v;
-                       event.m_timeStamp = ev->when;
-                       event.SetEventObject(focus);
-                       bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
-                       if ( !handled )
-                       {
-                               #if wxUSE_ACCEL
-                           if (!handled)
-                           {
-                               wxWindow *ancestor = focus;
-                               /*
-                               while (ancestor)
-                               {
-                                   int command = ancestor->GetAcceleratorTable()->GetCommand( event );
-                                   if (command != -1)
-                                   {
-                                       wxCommandEvent command_event( wxEVT_COMMAND_MENU_SELECTED, command );
-                                       handled = ancestor->GetEventHandler()->ProcessEvent( command_event );
-                                       break;
-                                   }
-                                   if (ancestor->m_isFrame)
-                                       break;
-                                   ancestor = ancestor->GetParent();
-                               }
-                               */
-                           }
-                               #endif // wxUSE_ACCEL
-                       }
-                       if (!handled)
-                       {
-                               wxKeyEvent event(wxEVT_CHAR);
-                               event.m_shiftDown = ev->modifiers & shiftKey;
-                               event.m_controlDown = ev->modifiers & controlKey;
-                               event.m_altDown = ev->modifiers & optionKey;
-                               event.m_metaDown = ev->modifiers & cmdKey;
-                               event.m_keyCode = keyval;
-                               event.m_x = ev->where.h;
-                               event.m_y = ev->where.v;
-                               event.m_timeStamp = ev->when;
-                               event.SetEventObject(focus);
-                               handled = focus->GetEventHandler()->ProcessEvent( event ) ;
-                       }
-                       if ( !handled &&
-                        (keyval == WXK_TAB) &&
-                        (!focus->HasFlag(wxTE_PROCESS_TAB)) &&
-                        (focus->GetParent()) &&
-                        (focus->GetParent()->HasFlag( wxTAB_TRAVERSAL)) )
-                   {
-                       wxNavigationKeyEvent new_event;
-                       new_event.SetEventObject( focus );
-                       new_event.SetDirection( !event.ShiftDown() );
-                       /* CTRL-TAB changes the (parent) window, i.e. switch notebook page */
-                       new_event.SetWindowChange( event.ControlDown() );
-                       new_event.SetCurrentFocus( focus );
-                       handled = focus->GetEventHandler()->ProcessEvent( new_event );
-                   }
-                   /* generate wxID_CANCEL if command-. or <esc> has been pressed (typically in dialogs) */
-                   if ( (!handled) &&
-                        (keyval == '.' && event.ControlDown() ) )
-                   {
-                       wxCommandEvent new_event(wxEVT_COMMAND_BUTTON_CLICKED,wxID_CANCEL);
-                       new_event.SetEventObject( focus );
-                       handled = focus->GetEventHandler()->ProcessEvent( new_event );
-                   }
-               }
-       }
+    wxToolTip::RemoveToolTips() ;
+
+    UInt32 menuresult = UMAMenuEvent(ev) ;
+    if ( HiWord( menuresult ) )
+    {
+        if ( !s_macIsInModalLoop )
+        MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) ) ;
+    }
+    else
+    {
+        short keycode ;
+        short keychar ;
+        keychar = short(ev->message & charCodeMask);
+        keycode = short(ev->message & keyCodeMask) >> 8 ;
+
+        wxWindow* focus = wxWindow::FindFocus() ;
+        if ( focus )
+        {
+            long keyval = wxMacTranslateKey(keychar, keycode) ;
+
+            wxKeyEvent event(wxEVT_KEY_DOWN);
+            event.m_shiftDown = ev->modifiers & shiftKey;
+            event.m_controlDown = ev->modifiers & controlKey;
+            event.m_altDown = ev->modifiers & optionKey;
+            event.m_metaDown = ev->modifiers & cmdKey;
+            event.m_keyCode = keyval;
+            event.m_x = ev->where.h;
+            event.m_y = ev->where.v;
+            event.m_timeStamp = ev->when;
+            event.SetEventObject(focus);
+            bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
+            if ( !handled )
+            {
+                #if wxUSE_ACCEL
+                if (!handled)
+                {
+                    wxWindow *ancestor = focus;
+                    /*
+                    while (ancestor)
+                    {
+                        int command = ancestor->GetAcceleratorTable()->GetCommand( event );
+                        if (command != -1)
+                        {
+                            wxCommandEvent command_event( wxEVT_COMMAND_MENU_SELECTED, command );
+                            handled = ancestor->GetEventHandler()->ProcessEvent( command_event );
+                            break;
+                        }
+                        if (ancestor->m_isFrame)
+                            break;
+                        ancestor = ancestor->GetParent();
+                    }
+                    */
+                }
+                #endif // wxUSE_ACCEL
+            }
+            if (!handled)
+            {
+                wxKeyEvent event(wxEVT_CHAR);
+                event.m_shiftDown = ev->modifiers & shiftKey;
+                event.m_controlDown = ev->modifiers & controlKey;
+                event.m_altDown = ev->modifiers & optionKey;
+                event.m_metaDown = ev->modifiers & cmdKey;
+                event.m_keyCode = keyval;
+                event.m_x = ev->where.h;
+                event.m_y = ev->where.v;
+                event.m_timeStamp = ev->when;
+                event.SetEventObject(focus);
+                handled = focus->GetEventHandler()->ProcessEvent( event ) ;
+            }
+            if ( !handled &&
+                 (keyval == WXK_TAB) &&
+                 (!focus->HasFlag(wxTE_PROCESS_TAB)) &&
+                 (focus->GetParent()) &&
+                 (focus->GetParent()->HasFlag( wxTAB_TRAVERSAL)) )
+            {
+                wxNavigationKeyEvent new_event;
+                new_event.SetEventObject( focus );
+                new_event.SetDirection( !event.ShiftDown() );
+                /* CTRL-TAB changes the (parent) window, i.e. switch notebook page */
+                new_event.SetWindowChange( event.ControlDown() );
+                new_event.SetCurrentFocus( focus );
+                handled = focus->GetEventHandler()->ProcessEvent( new_event );
+            }
+            /* generate wxID_CANCEL if command-. or <esc> has been pressed (typically in dialogs) */
+            if ( (!handled) &&
+                 (keyval == '.' && event.ControlDown() ) )
+            {
+                wxCommandEvent new_event(wxEVT_COMMAND_BUTTON_CLICKED,wxID_CANCEL);
+                new_event.SetEventObject( focus );
+                handled = focus->GetEventHandler()->ProcessEvent( new_event );
+            }
+        }
+    }
 }
 
 void wxApp::MacHandleKeyUpEvent( EventRecord *ev )
 {
-       wxToolTip::RemoveToolTips() ;
-       
-       UInt32 menuresult = UMAMenuEvent(ev) ;
-       if ( HiWord( menuresult ) )
-       {
-       }
-       else
-       {
-               short keycode ;
-               short keychar ;
-               keychar = short(ev->message & charCodeMask);
-               keycode = short(ev->message & keyCodeMask) >> 8 ;
-
-               wxWindow* focus = wxWindow::FindFocus() ;
-               if ( focus )
-               {
-                       long keyval = wxMacTranslateKey(keychar, keycode) ;
-                       
-                       wxKeyEvent event(wxEVT_KEY_UP);
-                       event.m_shiftDown = ev->modifiers & shiftKey;
-                       event.m_controlDown = ev->modifiers & controlKey;
-                       event.m_altDown = ev->modifiers & optionKey;
-                       event.m_metaDown = ev->modifiers & cmdKey;
-                       event.m_keyCode = keyval;
-                       event.m_x = ev->where.h;
-                       event.m_y = ev->where.v;
-                       event.m_timeStamp = ev->when;
-                       event.SetEventObject(focus);
-                       bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
-               }
-       }
+    wxToolTip::RemoveToolTips() ;
+
+    UInt32 menuresult = UMAMenuEvent(ev) ;
+    if ( HiWord( menuresult ) )
+    {
+    }
+    else
+    {
+        short keycode ;
+        short keychar ;
+        keychar = short(ev->message & charCodeMask);
+        keycode = short(ev->message & keyCodeMask) >> 8 ;
+
+        wxWindow* focus = wxWindow::FindFocus() ;
+        if ( focus )
+        {
+            long keyval = wxMacTranslateKey(keychar, keycode) ;
+
+            wxKeyEvent event(wxEVT_KEY_UP);
+            event.m_shiftDown = ev->modifiers & shiftKey;
+            event.m_controlDown = ev->modifiers & controlKey;
+            event.m_altDown = ev->modifiers & optionKey;
+            event.m_metaDown = ev->modifiers & cmdKey;
+            event.m_keyCode = keyval;
+            event.m_x = ev->where.h;
+            event.m_y = ev->where.v;
+            event.m_timeStamp = ev->when;
+            event.SetEventObject(focus);
+            bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
+        }
+    }
 }
 
 void wxApp::MacHandleActivateEvent( EventRecord *ev )
 {
-       WindowRef window = (WindowRef) ev->message ;
-       if ( window )
-       {
-               bool activate = (ev->modifiers & activeFlag ) ;
-               WindowClass wclass ;
-               UMAGetWindowClass ( window , &wclass ) ;
-               if ( wclass == kFloatingWindowClass )
-               {
-                       // if it is a floater we activate/deactivate the front non-floating window instead
-                       window = UMAFrontNonFloatingWindow() ;
-               }
-               wxWindow* win = wxFindWinFromMacWindow( window ) ;
-               if ( win )
-                       win->MacActivate( ev , activate ) ;
-       }
+    WindowRef window = (WindowRef) ev->message ;
+    if ( window )
+    {
+        bool activate = (ev->modifiers & activeFlag ) ;
+        WindowClass wclass ;
+        UMAGetWindowClass ( window , &wclass ) ;
+        if ( wclass == kFloatingWindowClass )
+        {
+            // if it is a floater we activate/deactivate the front non-floating window instead
+            window = UMAFrontNonFloatingWindow() ;
+        }
+        wxWindow* win = wxFindWinFromMacWindow( window ) ;
+        if ( win )
+            win->MacActivate( ev , activate ) ;
+    }
 }
 
 void wxApp::MacHandleUpdateEvent( EventRecord *ev )
 {
-       WindowRef window = (WindowRef) ev->message ;
-       wxWindow * win = wxFindWinFromMacWindow( window ) ;
-       if ( win )
-       {
+    WindowRef window = (WindowRef) ev->message ;
+    wxWindow * win = wxFindWinFromMacWindow( window ) ;
+    if ( win )
+    {
         if ( !wxPendingDelete.Member(win) )
-                       win->MacUpdate( ev ) ;
-       }
-       else
-       {
-               // since there is no way of telling this foreign window to update itself
-               // we have to invalidate the update region otherwise we keep getting the same
-               // event over and over again
-               BeginUpdate( window ) ;
-               EndUpdate( window ) ;
-       }
+            win->MacUpdate( ev ) ;
+    }
+    else
+    {
+        // since there is no way of telling this foreign window to update itself
+        // we have to invalidate the update region otherwise we keep getting the same
+        // event over and over again
+        BeginUpdate( window ) ;
+        EndUpdate( window ) ;
+    }
 }
 
 void wxApp::MacHandleDiskEvent( EventRecord *ev )
 {
-       if ( HiWord( ev->message ) != noErr )
+    if ( HiWord( ev->message ) != noErr )
   {
  #if !TARGET_CARBON
-               OSErr err ;
-               Point point ;
-               SetPt( &point , 100 , 100 ) ;
+        OSErr err ;
+        Point point ;
+         SetPt( &point , 100 , 100 ) ;
 
-               err = DIBadMount( point , ev->message ) ;
-               wxASSERT( err == noErr ) ;
+          err = DIBadMount( point , ev->message ) ;
+        wxASSERT( err == noErr ) ;
 #endif
-       }
+    }
 }
 
 void wxApp::MacHandleOSEvent( EventRecord *ev )
 {
-       switch( ( ev->message & osEvtMessageMask ) >> 24 )
-       {
-               case suspendResumeMessage :
-                       {
-                               bool isResuming = ev->message & resumeFlag ;
+    switch( ( ev->message & osEvtMessageMask ) >> 24 )
+    {
+        case suspendResumeMessage :
+            {
+                bool isResuming = ev->message & resumeFlag ;
 #if !TARGET_CARBON
-                               bool convertClipboard = ev->message & convertClipboardFlag ;
+                bool convertClipboard = ev->message & convertClipboardFlag ;
 #else
-                               bool convertClipboard = false;
+                bool convertClipboard = false;
 #endif
-                               bool doesActivate = UMAGetProcessModeDoesActivateOnFGSwitch() ;
-                               if ( isResuming )
-                               {
-                                       WindowRef oldFrontWindow = NULL ;
-                                       WindowRef newFrontWindow = NULL ;
-
-                                       // in case we don't take care of activating ourselves, we have to synchronize
-                                       // our idea of the active window with the process manager's - which it already activated
-
-                                       if ( !doesActivate )
-                                               oldFrontWindow = UMAFrontNonFloatingWindow() ;
-
-                                       MacResume( convertClipboard ) ;
-
-                                       newFrontWindow = UMAFrontNonFloatingWindow() ;
-
-                                       if ( oldFrontWindow )
-                                       {
-                                               wxWindow* win = wxFindWinFromMacWindow( oldFrontWindow ) ;
-                                               if ( win )
-                                                       win->MacActivate( ev , false ) ;
-                                       }
-                                       if ( newFrontWindow )
-                                       {
-                                               wxWindow* win = wxFindWinFromMacWindow( newFrontWindow ) ;
-                                               if ( win )
-                                                       win->MacActivate( ev , true ) ;
-                                       }
-                               }
-                               else
-                               {
-                                       MacSuspend( convertClipboard ) ;
-
-                                       // in case this suspending did close an active window, another one might
-                                       // have surfaced -> lets deactivate that one
-
-                                       WindowRef newActiveWindow = UMAGetActiveNonFloatingWindow() ;
-                                       if ( newActiveWindow )
-                                       {
-                                               wxWindow* win = wxFindWinFromMacWindow( newActiveWindow ) ;
-                                               if ( win )
-                                                       win->MacActivate( ev , false ) ;
-                                       }
-                               }
-                       }
-                       break ;
-               case mouseMovedMessage :
-                       {
-                               WindowRef window;
-
-                               wxWindow* currentMouseWindow = NULL ;
-
-                               wxWindow::MacGetWindowFromPoint( wxPoint( ev->where.h , ev->where.v ) ,
-                                                                                                &currentMouseWindow ) ;
-
-                               if ( currentMouseWindow != wxWindow::s_lastMouseWindow )
-                               {
-                                       wxMouseEvent event ;
-
-                                       bool isDown = !(ev->modifiers & btnState) ; // 1 is for up
-                                       bool controlDown = ev->modifiers & controlKey ; // for simulating right mouse
-
-                                       event.m_leftDown = isDown && !controlDown;
-                                       event.m_middleDown = FALSE;
-                                       event.m_rightDown = isDown && controlDown;
-                                       event.m_shiftDown = ev->modifiers & shiftKey;
-                                       event.m_controlDown = ev->modifiers & controlKey;
-                                       event.m_altDown = ev->modifiers & optionKey;
-                                       event.m_metaDown = ev->modifiers & cmdKey;
-                                       event.m_x = ev->where.h;
-                                       event.m_y = ev->where.v;
-                                       event.m_timeStamp = ev->when;
-                                       event.SetEventObject(this);
-
-                                       if ( wxWindow::s_lastMouseWindow )
-                                       {
-                                               wxMouseEvent eventleave(event ) ;
-                                               eventleave.SetEventType( wxEVT_LEAVE_WINDOW ) ;
-                                               wxWindow::s_lastMouseWindow->GetEventHandler()->ProcessEvent(eventleave);
-                                       }
-                                       if ( currentMouseWindow )
-                                       {
-                                               wxMouseEvent evententer(event ) ;
-                                               evententer.SetEventType( wxEVT_ENTER_WINDOW ) ;
-                                               currentMouseWindow->GetEventHandler()->ProcessEvent(evententer);
-                                       }
-                                       wxWindow::s_lastMouseWindow = currentMouseWindow ;
-                               }
-
-                               short windowPart = ::FindWindow(ev->where, &window);
-
-                               switch (windowPart)
-                               {
-                                       // fixes for setting the cursor back from dominic mazzoni
-                                       case inMenuBar :
-                                           UMAShowArrowCursor();
-                                               break ;
-                                       case inSysWindow :
-                                           UMAShowArrowCursor();
-                                               break ;
-                                       default:
-                                               {
-                                                       if ( s_lastMouseDown == 0 )
-                                                               ev->modifiers |= btnState ;
-
-                                                       wxWindow* win = wxFindWinFromMacWindow( window ) ;
-                                                       if ( win )
-                                                               win->MacMouseMoved( ev , windowPart ) ;
-                                                       else                                       
-                                                       UMAShowArrowCursor();
-
-                                               }
-                                               break;
-                               }
-                       }
-                       break ;
-
-       }
+                bool doesActivate = UMAGetProcessModeDoesActivateOnFGSwitch() ;
+                if ( isResuming )
+                {
+                    WindowRef oldFrontWindow = NULL ;
+                    WindowRef newFrontWindow = NULL ;
+
+                    // in case we don't take care of activating ourselves, we have to synchronize
+                    // our idea of the active window with the process manager's - which it already activated
+
+                    if ( !doesActivate )
+                        oldFrontWindow = UMAFrontNonFloatingWindow() ;
+
+                    MacResume( convertClipboard ) ;
+
+                    newFrontWindow = UMAFrontNonFloatingWindow() ;
+
+                    if ( oldFrontWindow )
+                    {
+                        wxWindow* win = wxFindWinFromMacWindow( oldFrontWindow ) ;
+                        if ( win )
+                            win->MacActivate( ev , false ) ;
+                    }
+                    if ( newFrontWindow )
+                    {
+                        wxWindow* win = wxFindWinFromMacWindow( newFrontWindow ) ;
+                        if ( win )
+                            win->MacActivate( ev , true ) ;
+                    }
+                }
+                else
+                {
+                    MacSuspend( convertClipboard ) ;
+
+                    // in case this suspending did close an active window, another one might
+                    // have surfaced -> lets deactivate that one
+
+                    WindowRef newActiveWindow = UMAGetActiveNonFloatingWindow() ;
+                    if ( newActiveWindow )
+                    {
+                        wxWindow* win = wxFindWinFromMacWindow( newActiveWindow ) ;
+                        if ( win )
+                            win->MacActivate( ev , false ) ;
+                    }
+                }
+            }
+            break ;
+        case mouseMovedMessage :
+            {
+                WindowRef window;
+
+                wxWindow* currentMouseWindow = NULL ;
+
+                wxWindow::MacGetWindowFromPoint( wxPoint( ev->where.h , ev->where.v ) ,
+                                                 &currentMouseWindow ) ;
+
+                if ( currentMouseWindow != wxWindow::s_lastMouseWindow )
+                {
+                    wxMouseEvent event ;
+
+                    bool isDown = !(ev->modifiers & btnState) ; // 1 is for up
+                    bool controlDown = ev->modifiers & controlKey ; // for simulating right mouse
+
+                    event.m_leftDown = isDown && !controlDown;
+                    event.m_middleDown = FALSE;
+                    event.m_rightDown = isDown && controlDown;
+                    event.m_shiftDown = ev->modifiers & shiftKey;
+                    event.m_controlDown = ev->modifiers & controlKey;
+                    event.m_altDown = ev->modifiers & optionKey;
+                    event.m_metaDown = ev->modifiers & cmdKey;
+                    event.m_x = ev->where.h;
+                    event.m_y = ev->where.v;
+                    event.m_timeStamp = ev->when;
+                    event.SetEventObject(this);
+
+                    if ( wxWindow::s_lastMouseWindow )
+                    {
+                        wxMouseEvent eventleave(event ) ;
+                        eventleave.SetEventType( wxEVT_LEAVE_WINDOW ) ;
+                        wxWindow::s_lastMouseWindow->GetEventHandler()->ProcessEvent(eventleave);
+                    }
+                    if ( currentMouseWindow )
+                    {
+                        wxMouseEvent evententer(event ) ;
+                        evententer.SetEventType( wxEVT_ENTER_WINDOW ) ;
+                        currentMouseWindow->GetEventHandler()->ProcessEvent(evententer);
+                    }
+                    wxWindow::s_lastMouseWindow = currentMouseWindow ;
+                }
+
+                short windowPart = ::FindWindow(ev->where, &window);
+
+                switch (windowPart)
+                {
+                    // fixes for setting the cursor back from dominic mazzoni
+                    case inMenuBar :
+                        UMAShowArrowCursor();
+                        break ;
+                    case inSysWindow :
+                        UMAShowArrowCursor();
+                        break ;
+                    default:
+                        {
+                            if ( s_lastMouseDown == 0 )
+                                ev->modifiers |= btnState ;
+
+                            wxWindow* win = wxFindWinFromMacWindow( window ) ;
+                            if ( win )
+                                win->MacMouseMoved( ev , windowPart ) ;
+                            else
+                                UMAShowArrowCursor();
+
+                        }
+                        break;
+                }
+            }
+            break ;
+
+    }
 }
 
 void wxApp::MacHandleMenuSelect( int macMenuId , int macMenuItemNum )
 {
-       if (macMenuId == 0)
-                return; // no menu item selected
-
-       if (macMenuId == kwxMacAppleMenuId && macMenuItemNum > 1)
-       {
-               #if ! TARGET_CARBON
-               Str255          deskAccessoryName ;
-               GrafPtr         savedPort ;
-
-               GetMenuItemText(GetMenuHandle(kwxMacAppleMenuId), macMenuItemNum, deskAccessoryName);
-               GetPort(&savedPort);
-               OpenDeskAcc(deskAccessoryName);
-               SetPort(savedPort);
-               #endif
-       }
-       else
-       {
-               wxWindow* frontwindow = wxFindWinFromMacWindow( ::FrontWindow() )  ;
-               if ( frontwindow && wxMenuBar::MacGetInstalledMenuBar() )
-                       wxMenuBar::MacGetInstalledMenuBar()->MacMenuSelect( frontwindow->GetEventHandler() , 0 , macMenuId , macMenuItemNum ) ;
-       }
-       HiliteMenu(0);
+    if (macMenuId == 0)
+         return; // no menu item selected
+
+    if (macMenuId == kwxMacAppleMenuId && macMenuItemNum > 1)
+    {
+        #if ! TARGET_CARBON
+        Str255        deskAccessoryName ;
+        GrafPtr        savedPort ;
+
+        GetMenuItemText(GetMenuHandle(kwxMacAppleMenuId), macMenuItemNum, deskAccessoryName);
+        GetPort(&savedPort);
+        OpenDeskAcc(deskAccessoryName);
+        SetPort(savedPort);
+        #endif
+    }
+    else
+    {
+        wxWindow* frontwindow = wxFindWinFromMacWindow( ::FrontWindow() )  ;
+        if ( frontwindow && wxMenuBar::MacGetInstalledMenuBar() )
+            wxMenuBar::MacGetInstalledMenuBar()->MacMenuSelect( frontwindow->GetEventHandler() , 0 , macMenuId , macMenuItemNum ) ;
+    }
+    HiliteMenu(0);
 }
 
 /*
@@ -1741,12 +1737,12 @@ wxApp::macAdjustCursor()
 {
   if (ev->what != kHighLevelEvent)
   {
-       wxWindow* theMacWxFrame = wxFrame::MacFindFrameOrDialog(::FrontWindow());
-       if (theMacWxFrame)
-       {
-         if (!theMacWxFrame->MacAdjustCursor(ev->where))
-               ::SetCursor(&(qd.arrow));
-       }
+    wxWindow* theMacWxFrame = wxFrame::MacFindFrameOrDialog(::FrontWindow());
+    if (theMacWxFrame)
+    {
+        if (!theMacWxFrame->MacAdjustCursor(ev->where))
+        ::SetCursor(&(qd.arrow));
+      }
   }
 }
 */
index 095156baa187df2d8d20e785a23836b7bc68688e..ade0e6938efc7c63077b31986b3a14aad42592db 100644 (file)
@@ -6,7 +6,7 @@
 // Created:     ??/??/98
 // RCS-ID:      $Id$
 // Copyright:   (c) AUTHOR
-// Licence:    wxWindows licence
+// Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
 #ifdef __GNUG__
@@ -43,7 +43,7 @@
 
 #ifndef __DARWIN__
   #if __option(profile)
-       #include <profiler.h>
+    #include <profiler.h>
   #endif
 #endif
 
@@ -78,18 +78,18 @@ END_EVENT_TABLE()
 #endif
 
 
-const short    kMacMinHeap = (29 * 1024) ;
+const short    kMacMinHeap = (29 * 1024) ;
 // platform specific static variables
 
 const short kwxMacMenuBarResource = 1 ;
 const short kwxMacAppleMenuId = 1 ;
 
-RgnHandle                      wxApp::s_macCursorRgn = NULL;
-wxWindow*                      wxApp::s_captureWindow = NULL ;
-int                                    wxApp::s_lastMouseDown = 0 ;
-long                                   wxApp::sm_lastMessageTime = 0;
+RgnHandle            wxApp::s_macCursorRgn = NULL;
+wxWindow*            wxApp::s_captureWindow = NULL ;
+int                    wxApp::s_lastMouseDown = 0 ;
+long                     wxApp::sm_lastMessageTime = 0;
 
-bool   wxApp::s_macDefaultEncodingIsPC = true ;
+bool    wxApp::s_macDefaultEncodingIsPC = true ;
 bool wxApp::s_macSupportPCMenuShortcuts = true ;
 long wxApp::s_macAboutMenuItemId = wxID_ABOUT ;
 wxString wxApp::s_macHelpMenuTitleName = "&Help" ;
@@ -100,8 +100,8 @@ pascal OSErr AEHandleODoc( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandleODoc( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEODoc( (AppleEvent*) event , reply) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEODoc( (AppleEvent*) event , reply) ;
 }
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
@@ -110,8 +110,8 @@ pascal OSErr AEHandleOApp( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandleOApp( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEOApp( (AppleEvent*) event , reply ) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEOApp( (AppleEvent*) event , reply ) ;
 }
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
@@ -120,8 +120,8 @@ pascal OSErr AEHandlePDoc( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandlePDoc( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEPDoc( (AppleEvent*) event , reply ) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEPDoc( (AppleEvent*) event , reply ) ;
 }
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
@@ -130,254 +130,254 @@ pascal OSErr AEHandleQuit( const AppleEvent *event , AppleEvent *reply , long re
 pascal OSErr AEHandleQuit( const AppleEvent *event , AppleEvent *reply , unsigned long refcon )
 #endif
 {
-       wxApp* app = (wxApp*) refcon ;
-       return wxTheApp->MacHandleAEQuit( (AppleEvent*) event , reply) ;
+    wxApp* app = (wxApp*) refcon ;
+    return wxTheApp->MacHandleAEQuit( (AppleEvent*) event , reply) ;
 }
 
 OSErr wxApp::MacHandleAEODoc(const AppleEvent *event , AppleEvent *reply)
 {
     SysBeep(40) ;
-       ProcessSerialNumber PSN ;
-       PSN.highLongOfPSN = 0 ;
-       PSN.lowLongOfPSN = kCurrentProcess ;
-       SetFrontProcess( &PSN ) ;
-       return noErr ;
+    ProcessSerialNumber PSN ;
+    PSN.highLongOfPSN = 0 ;
+    PSN.lowLongOfPSN = kCurrentProcess ;
+    SetFrontProcess( &PSN ) ;
+    return noErr ;
 }
 
 OSErr wxApp::MacHandleAEPDoc(const AppleEvent *event , AppleEvent *reply)
 {
-       return noErr ;
+    return noErr ;
 }
 
 OSErr wxApp::MacHandleAEOApp(const AppleEvent *event , AppleEvent *reply)
 {
-       return noErr ;
+    return noErr ;
 }
 
 OSErr wxApp::MacHandleAEQuit(const AppleEvent *event , AppleEvent *reply)
 {
-       wxWindow* win = GetTopWindow() ;
-       if ( win )
-       {
-               win->Close(TRUE ) ;
-       }
-       else
-       {
-               ExitMainLoop() ;
-       }
-       return noErr ;
+    wxWindow* win = GetTopWindow() ;
+    if ( win )
+    {
+        win->Close(TRUE ) ;
+    }
+    else
+    {
+        ExitMainLoop() ;
+    }
+    return noErr ;
 }
 
-char StringMac[] =     "\x0d\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f"
-                                       "\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f"
-                                       "\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xae\xaf"
-                                       "\xb1\xb4\xb5\xb6\xbb\xbc\xbe\xbf"
-                                       "\xc0\xc1\xc2\xc4\xc7\xc8\xc9\xcb\xcc\xcd\xce\xcf"
-                                       "\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd8\xca\xdb" ;
+char StringMac[] =     "\x0d\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f"
+                    "\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f"
+                    "\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xae\xaf"
+                    "\xb1\xb4\xb5\xb6\xbb\xbc\xbe\xbf"
+                    "\xc0\xc1\xc2\xc4\xc7\xc8\xc9\xcb\xcc\xcd\xce\xcf"
+                    "\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd8\xca\xdb" ;
 
 char StringANSI[] = "\x0a\xC4\xC5\xC7\xC9\xD1\xD6\xDC\xE1\xE0\xE2\xE4\xE3\xE5\xE7\xE9\xE8"
-                                       "\xEA\xEB\xED\xEC\xEE\xEF\xF1\xF3\xF2\xF4\xF6\xF5\xFA\xF9\xFB\xFC"
-                                       "\x86\xBA\xA2\xA3\xA7\x95\xB6\xDF\xAE\xA9\x99\xB4\xA8\xC6\xD8"
-                                       "\xB1\xA5\xB5\xF0\xAA\xBA\xE6\xF8"
-                                       "\xBF\xA1\xAC\x83\xAB\xBB\x85\xC0\xC3\xD5\x8C\x9C"
-                                       "\x96\x97\x93\x94\x91\x92\xF7\xFF\xA0\x80" ;
+                    "\xEA\xEB\xED\xEC\xEE\xEF\xF1\xF3\xF2\xF4\xF6\xF5\xFA\xF9\xFB\xFC"
+                    "\x86\xBA\xA2\xA3\xA7\x95\xB6\xDF\xAE\xA9\x99\xB4\xA8\xC6\xD8"
+                    "\xB1\xA5\xB5\xF0\xAA\xBA\xE6\xF8"
+                    "\xBF\xA1\xAC\x83\xAB\xBB\x85\xC0\xC3\xD5\x8C\x9C"
+                    "\x96\x97\x93\x94\x91\x92\xF7\xFF\xA0\x80" ;
 
 void wxMacConvertFromPC( const char *from , char *to , int len )
 {
-       char *c ;
-       if ( from == to )
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringANSI , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringMac[ c - StringANSI] ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
-       else
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringANSI , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringMac[ c - StringANSI] ;
-                       }
-                       else
-                       {
-                               *to = *from ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
+    char *c ;
+    if ( from == to )
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringANSI , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringMac[ c - StringANSI] ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
+    else
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringANSI , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringMac[ c - StringANSI] ;
+            }
+            else
+            {
+                *to = *from ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
 }
 
 void wxMacConvertToPC( const char *from , char *to , int len )
 {
-       char *c ;
-       if ( from == to )
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringMac , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringANSI[ c - StringMac] ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
-       else
-       {
-               for( int i = 0 ; i < len ; ++ i )
-               {
-                       c = strchr( StringMac , *from ) ;
-                       if ( c != NULL )
-                       {
-                               *to = StringANSI[ c - StringMac] ;
-                       }
-                       else
-                       {
-                               *to = *from ;
-                       }
-                       ++to ;
-                       ++from ;
-               }
-       }
+    char *c ;
+    if ( from == to )
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringMac , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringANSI[ c - StringMac] ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
+    else
+    {
+        for( int i = 0 ; i < len ; ++ i )
+        {
+            c = strchr( StringMac , *from ) ;
+            if ( c != NULL )
+            {
+                *to = StringANSI[ c - StringMac] ;
+            }
+            else
+            {
+                *to = *from ;
+            }
+            ++to ;
+            ++from ;
+        }
+    }
 }
 
 void wxMacConvertFromPC( char * p )
 {
-       char *ptr = p ;
-       int len = strlen ( p ) ;
+    char *ptr = p ;
+    int len = strlen ( p ) ;
 
-       wxMacConvertFromPC( ptr , ptr , len ) ;
+    wxMacConvertFromPC( ptr , ptr , len ) ;
 }
 
 void wxMacConvertFromPCForControls( char * p )
 {
-       char *ptr = p ;
-       int len = strlen ( p ) ;
-
-       wxMacConvertFromPC( ptr , ptr , len ) ;
-       for ( int i = 0 ; i < strlen ( ptr ) ; i++ )
-       {
-               if ( ptr[i] == '&' && ptr[i]+1 != ' ' )
-               {
-                       memmove( &ptr[i] , &ptr[i+1] , strlen( &ptr[i+1] ) + 1) ;
-               }
-       }
+    char *ptr = p ;
+    int len = strlen ( p ) ;
+
+    wxMacConvertFromPC( ptr , ptr , len ) ;
+    for ( int i = 0 ; i < strlen ( ptr ) ; i++ )
+    {
+        if ( ptr[i] == '&' && ptr[i]+1 != ' ' )
+        {
+            memmove( &ptr[i] , &ptr[i+1] , strlen( &ptr[i+1] ) + 1) ;
+        }
+    }
 }
 
 void wxMacConvertFromPC( unsigned char *p )
 {
-       char *ptr = (char*) p + 1 ;
-       int len = p[0] ;
+    char *ptr = (char*) p + 1 ;
+    int len = p[0] ;
 
-       wxMacConvertFromPC( ptr , ptr , len ) ;
+    wxMacConvertFromPC( ptr , ptr , len ) ;
 }
 
 extern char *wxBuffer ;
 
 wxString wxMacMakeMacStringFromPC( const char * p )
 {
-       const char *ptr = p ;
-       int len = strlen ( p ) ;
-       char *buf = wxBuffer ;
-
-       if ( len >= BUFSIZ + 512 )
-       {
-               buf = new char [len+1] ;
-       }
-
-       wxMacConvertFromPC( ptr , buf , len ) ;
-       buf[len] = 0 ;
-       wxString result( buf ) ;
-       if ( buf != wxBuffer )
-               delete buf ;
-       return result ;
+    const char *ptr = p ;
+    int len = strlen ( p ) ;
+    char *buf = wxBuffer ;
+
+    if ( len >= BUFSIZ + 512 )
+    {
+        buf = new char [len+1] ;
+    }
+
+    wxMacConvertFromPC( ptr , buf , len ) ;
+    buf[len] = 0 ;
+    wxString result( buf ) ;
+    if ( buf != wxBuffer )
+        delete buf ;
+    return result ;
 }
 
 
 void wxMacConvertToPC( char * p )
 {
-       char *ptr = p ;
-       int len = strlen ( p ) ;
+    char *ptr = p ;
+    int len = strlen ( p ) ;
 
-       wxMacConvertToPC( ptr , ptr , len ) ;
+    wxMacConvertToPC( ptr , ptr , len ) ;
 }
 
 void wxMacConvertToPC( unsigned char *p )
 {
-       char *ptr = (char*) p + 1 ;
-       int len = p[0] ;
+    char *ptr = (char*) p + 1 ;
+    int len = p[0] ;
 
-       wxMacConvertToPC( ptr , ptr , len ) ;
+    wxMacConvertToPC( ptr , ptr , len ) ;
 }
 
 wxString wxMacMakePCStringFromMac( const char * p )
 {
-       const char *ptr = p ;
-       int len = strlen ( p ) ;
-       char *buf = wxBuffer ;
-
-       if ( len >= BUFSIZ + 512 )
-       {
-               buf = new char [len+1] ;
-       }
-
-       wxMacConvertToPC( ptr , buf , len ) ;
-       buf[len] = 0 ;
-
-       wxString result( buf ) ;
-       if ( buf != wxBuffer )
-               delete buf ;
-       return result ;
+    const char *ptr = p ;
+    int len = strlen ( p ) ;
+    char *buf = wxBuffer ;
+
+    if ( len >= BUFSIZ + 512 )
+    {
+        buf = new char [len+1] ;
+    }
+
+    wxMacConvertToPC( ptr , buf , len ) ;
+    buf[len] = 0 ;
+
+    wxString result( buf ) ;
+    if ( buf != wxBuffer )
+        delete buf ;
+    return result ;
 }
 
-wxString wxMacMakeStringFromMacString( const char* from , bool mac2pcEncoding ) 
+wxString wxMacMakeStringFromMacString( const char* from , bool mac2pcEncoding )
 {
-       if (mac2pcEncoding)
-       {
-         return wxMacMakePCStringFromMac( from ) ;
-       }
-       else
-       {
-         return wxString( from ) ;
-       }
+    if (mac2pcEncoding)
+    {
+      return wxMacMakePCStringFromMac( from ) ;
+    }
+    else
+    {
+      return wxString( from ) ;
+    }
 }
 
-wxString wxMacMakeStringFromPascal( StringPtr from , bool mac2pcEncoding ) 
+wxString wxMacMakeStringFromPascal( StringPtr from , bool mac2pcEncoding )
 {
   // this is safe since a pascal string can never be larger than 256 bytes
   char s[256] ;
   CopyPascalStringToC( from , s ) ;
-       if (mac2pcEncoding)
-       {
-         return wxMacMakePCStringFromMac( s ) ;
-       }
-       else
-       {
-         return wxString( s ) ;
-       }
+    if (mac2pcEncoding)
+    {
+      return wxMacMakePCStringFromMac( s ) ;
+    }
+    else
+    {
+      return wxString( s ) ;
+    }
 }
 
-void wxMacStringToPascal( const char * from , StringPtr to , bool pc2macEncoding ) 
+void wxMacStringToPascal( const char * from , StringPtr to , bool pc2macEncoding )
 {
-       if (pc2macEncoding)
-       {
-         CopyCStringToPascal( wxMacMakeMacStringFromPC( from ) , to ) ;
-       }
-       else
-       {
-         CopyCStringToPascal( from , to ) ;
-       }
+    if (pc2macEncoding)
+    {
+      CopyCStringToPascal( wxMacMakeMacStringFromPC( from ) , to ) ;
+    }
+    else
+    {
+      CopyCStringToPascal( from , to ) ;
+    }
 }
 
 bool wxApp::Initialize()
@@ -388,7 +388,7 @@ bool wxApp::Initialize()
 
   UMAInitToolbox( 4 ) ;
   SetEventMask( everyEvent ) ;
-       UMAShowWatchCursor() ;
+    UMAShowWatchCursor() ;
 
 #if defined(UNIVERSAL_INTERFACES_VERSION) && (UNIVERSAL_INTERFACES_VERSION >= 0x0340)
     AEInstallEventHandler( kCoreEventClass , kAEOpenDocuments ,   NewAEEventHandlerUPP(AEHandleODoc) ,
@@ -400,73 +400,73 @@ bool wxApp::Initialize()
     AEInstallEventHandler( kCoreEventClass , kAEQuitApplication , NewAEEventHandlerUPP(AEHandleQuit) ,
                            (long) wxTheApp , FALSE ) ;
 #else
-       AEInstallEventHandler( kCoreEventClass , kAEOpenDocuments ,   NewAEEventHandlerProc(AEHandleODoc) ,
-                              (long) wxTheApp , FALSE ) ;
-       AEInstallEventHandler( kCoreEventClass , kAEOpenApplication , NewAEEventHandlerProc(AEHandleOApp) ,
-                              (long) wxTheApp , FALSE ) ;
-       AEInstallEventHandler( kCoreEventClass , kAEPrintDocuments ,  NewAEEventHandlerProc(AEHandlePDoc) ,
-                              (long) wxTheApp , FALSE ) ;
-       AEInstallEventHandler( kCoreEventClass , kAEQuitApplication , NewAEEventHandlerProc(AEHandleQuit) ,
-                              (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEOpenDocuments ,   NewAEEventHandlerProc(AEHandleODoc) ,
+                   (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEOpenApplication , NewAEEventHandlerProc(AEHandleOApp) ,
+                   (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEPrintDocuments ,  NewAEEventHandlerProc(AEHandlePDoc) ,
+                   (long) wxTheApp , FALSE ) ;
+    AEInstallEventHandler( kCoreEventClass , kAEQuitApplication , NewAEEventHandlerProc(AEHandleQuit) ,
+                   (long) wxTheApp , FALSE ) ;
 #endif
 
 
 #ifndef __DARWIN__
   // test the minimal configuration necessary
 
-       #if !TARGET_CARBON
-       long theSystem ;
-       long theMachine; 
-
-       if (Gestalt(gestaltMachineType, &theMachine) != noErr)
-       {
-               error = kMacSTRWrongMachine;
-       }
-       else if (theMachine < gestaltMacPlus)
-       {
-               error = kMacSTRWrongMachine;
-       }
-       else if (Gestalt(gestaltSystemVersion, &theSystem) != noErr )
-       {
-               error = kMacSTROldSystem  ;
-       }
-       else if ( theSystem < 0x0750 )
-       {
-               error = kMacSTROldSystem  ;
-       }
-       else if ((long)GetApplLimit() - (long)ApplicationZone() < kMacMinHeap)
-       {
-               error = kMacSTRSmallSize;
-       }
-       #endif
-       /*
-       else
-       {
-               if ( !UMAHasAppearance() )
-               {
-                       error = kMacSTRNoPre8Yet ;
-               }
-       }
-       */
+    #if !TARGET_CARBON
+    long theSystem ;
+    long theMachine;
+
+    if (Gestalt(gestaltMachineType, &theMachine) != noErr)
+    {
+        error = kMacSTRWrongMachine;
+    }
+    else if (theMachine < gestaltMacPlus)
+    {
+        error = kMacSTRWrongMachine;
+    }
+    else if (Gestalt(gestaltSystemVersion, &theSystem) != noErr )
+    {
+        error = kMacSTROldSystem  ;
+    }
+    else if ( theSystem < 0x0750 )
+    {
+        error = kMacSTROldSystem  ;
+    }
+    else if ((long)GetApplLimit() - (long)ApplicationZone() < kMacMinHeap)
+    {
+        error = kMacSTRSmallSize;
+    }
+    #endif
+    /*
+    else
+    {
+        if ( !UMAHasAppearance() )
+        {
+            error = kMacSTRNoPre8Yet ;
+        }
+    }
+    */
 #endif
 
-       // if we encountered any problems so far, give the error code and exit immediately
+    // if we encountered any problems so far, give the error code and exit immediately
 
   if ( error )
   {
-               short itemHit;
-               Str255 message;
-
-               GetIndString(message, 128, error);
-               UMAShowArrowCursor() ;
-               ParamText("\pFatal Error", message, (ConstStr255Param)"\p", (ConstStr255Param)"\p");
-               itemHit = Alert(128, nil);
-         return FALSE ;
+        short itemHit;
+        Str255 message;
+
+        GetIndString(message, 128, error);
+        UMAShowArrowCursor() ;
+        ParamText("\pFatal Error", message, (ConstStr255Param)"\p", (ConstStr255Param)"\p");
+        itemHit = Alert(128, nil);
+      return FALSE ;
   }
 
 #ifndef __DARWIN__
   #if __option(profile)
-       ProfilerInit( collectDetailed, bestTimeBase , 20000 , 40 ) ;
+    ProfilerInit( collectDetailed, bestTimeBase , 20000 , 40 ) ;
   #endif
 #endif
 
@@ -476,7 +476,7 @@ bool wxApp::Initialize()
   std::__throws_bad_alloc = FALSE ;
 #endif
 
-       s_macCursorRgn = ::NewRgn() ;
+    s_macCursorRgn = ::NewRgn() ;
 
 #ifdef __WXMSW__
   wxBuffer = new char[1500];
@@ -529,7 +529,7 @@ bool wxApp::Initialize()
   wxMacCreateNotifierTable() ;
 
   UMAShowArrowCursor() ;
-  
+
   return TRUE;
 }
 
@@ -610,13 +610,13 @@ void wxApp::CleanUp()
     delete wxLog::SetActiveTarget(NULL);
 #endif // wxUSE_LOG
 
-       UMACleanupToolbox() ;
-       if (s_macCursorRgn)
-               ::DisposeRgn(s_macCursorRgn);
+    UMACleanupToolbox() ;
+    if (s_macCursorRgn)
+        ::DisposeRgn(s_macCursorRgn);
 
-       #if 0
-               TerminateAE() ;
-       #endif
+    #if 0
+        TerminateAE() ;
+    #endif
 }
 
 int wxEntry( int argc, char *argv[] , bool enterLoop )
@@ -668,40 +668,40 @@ int wxEntry( int argc, char *argv[] , bool enterLoop )
 
   int retValue = 0;
 
-       if ( wxTheApp->OnInit() )
-       {
-           if ( enterLoop )
-           {
-               retValue = wxTheApp->OnRun();
-           }
-           else
-               // We want to initialize, but not run or exit immediately.
-               return 1;
-       }
-       //else: app initialization failed, so we skipped OnRun()
-
-       wxWindow *topWindow = wxTheApp->GetTopWindow();
-       if ( topWindow )
-       {
-           // Forcibly delete the window.
-           if ( topWindow->IsKindOf(CLASSINFO(wxFrame)) ||
-                   topWindow->IsKindOf(CLASSINFO(wxDialog)) )
-           {
-               topWindow->Close(TRUE);
-               wxTheApp->DeletePendingObjects();
-           }
-           else
-           {
-               delete topWindow;
-               wxTheApp->SetTopWindow(NULL);
-           }
-       }
-       
-       wxTheApp->OnExit();
-       
-       wxApp::CleanUp();
-       
-       return retValue;
+    if ( wxTheApp->OnInit() )
+    {
+        if ( enterLoop )
+        {
+            retValue = wxTheApp->OnRun();
+        }
+        else
+            // We want to initialize, but not run or exit immediately.
+            return 1;
+    }
+    //else: app initialization failed, so we skipped OnRun()
+
+    wxWindow *topWindow = wxTheApp->GetTopWindow();
+    if ( topWindow )
+    {
+        // Forcibly delete the window.
+        if ( topWindow->IsKindOf(CLASSINFO(wxFrame)) ||
+                topWindow->IsKindOf(CLASSINFO(wxDialog)) )
+        {
+            topWindow->Close(TRUE);
+            wxTheApp->DeletePendingObjects();
+        }
+        else
+        {
+            delete topWindow;
+            wxTheApp->SetTopWindow(NULL);
+        }
+    }
+
+    wxTheApp->OnExit();
+
+    wxApp::CleanUp();
+
+    return retValue;
 }
 
 // Static member initialization
@@ -736,7 +736,7 @@ int wxApp::MainLoop()
 
   while (m_keepGoing)
   {
-               MacDoOneEvent() ;
+        MacDoOneEvent() ;
   }
 
   return 0;
@@ -760,7 +760,7 @@ void wxApp::ExitMainLoop()
 // Is a message/event pending?
 bool wxApp::Pending()
 {
-       EventRecord event ;
+    EventRecord event ;
 
   return EventAvail( everyEvent , &event ) ;
 }
@@ -768,7 +768,7 @@ bool wxApp::Pending()
 // Dispatch a message.
 void wxApp::Dispatch()
 {
-       MacDoOneEvent() ;
+    MacDoOneEvent() ;
 }
 
 void wxApp::OnIdle(wxIdleEvent& event)
@@ -806,22 +806,22 @@ void wxApp::OnIdle(wxIdleEvent& event)
 
 void wxWakeUpIdle()
 {
-       wxMacWakeUp() ;
+    wxMacWakeUp() ;
 }
 
 // Send idle event to all top-level windows
 bool wxApp::SendIdleEvents()
 {
     bool needMore = FALSE;
-       wxNode* node = wxTopLevelWindows.First();
-       while (node)
-       {
-               wxWindow* win = (wxWindow*) node->Data();
-               if (SendIdleEvents(win))
+    wxNode* node = wxTopLevelWindows.First();
+    while (node)
+    {
+        wxWindow* win = (wxWindow*) node->Data();
+        if (SendIdleEvents(win))
             needMore = TRUE;
 
-               node = node->Next();
-       }
+        node = node->Next();
+    }
     return needMore;
 }
 
@@ -830,22 +830,22 @@ bool wxApp::SendIdleEvents(wxWindow* win)
 {
     bool needMore = FALSE;
 
-       wxIdleEvent event;
-       event.SetEventObject(win);
-       win->ProcessEvent(event);
+    wxIdleEvent event;
+    event.SetEventObject(win);
+    win->ProcessEvent(event);
 
     if (event.MoreRequested())
         needMore = TRUE;
 
-       wxNode* node = win->GetChildren().First();
-       while (node)
-       {
-               wxWindow* win = (wxWindow*) node->Data();
-               if (SendIdleEvents(win))
+    wxNode* node = win->GetChildren().First();
+    while (node)
+    {
+        wxWindow* win = (wxWindow*) node->Data();
+        if (SendIdleEvents(win))
             needMore = TRUE;
 
-               node = node->Next();
-       }
+        node = node->Next();
+    }
     return needMore ;
 }
 
@@ -895,7 +895,7 @@ void wxExit()
     wxLogError(_("Fatal error: exiting"));
 
     wxApp::CleanUp();
-       ::ExitToShell() ;
+    ::ExitToShell() ;
 }
 
 void wxApp::OnEndSession(wxCloseEvent& WXUNUSED(event))
@@ -918,80 +918,76 @@ void wxApp::OnQueryEndSession(wxCloseEvent& event)
 extern "C" void wxCYield() ;
 void wxCYield()
 {
-       wxYield() ;
+    wxYield() ;
 }
 
 // Yield to other processes
 
-static bool gs_inYield = FALSE;
-
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
-#ifdef __WXDEBUG__    
-    if (gs_inYield)
-        wxFAIL_MSG( wxT("wxYield called recursively" ) );
-#endif
+    static bool s_inYield = FALSE;
+
+    if (s_inYield)
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( wxT("wxYield called recursively" ) );
+        }
+
+        return FALSE;
+    }
+
+    s_inYield = TRUE;
 
-    gs_inYield = TRUE;
-    
 #if wxUSE_THREADS
     YieldToAnyThread() ;
 #endif
     EventRecord event ;
 
-       long sleepTime = 1 ; //::GetCaretTime();
+    long sleepTime = 1 ; //::GetCaretTime();
 
-       while ( !wxTheApp->IsExiting() && WaitNextEvent(everyEvent, &event,sleepTime, wxApp::s_macCursorRgn))
-       {
-       wxTheApp->MacHandleOneEvent( &event );
-           if ( event.what != kHighLevelEvent )
-                   SetRectRgn( wxApp::s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
-       }
+    while ( !wxTheApp->IsExiting() && WaitNextEvent(everyEvent, &event,sleepTime, wxApp::s_macCursorRgn))
+    {
+        wxTheApp->MacHandleOneEvent( &event );
+        if ( event.what != kHighLevelEvent )
+            SetRectRgn( wxApp::s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
+    }
 
-       wxMacProcessNotifierAndPendingEvents() ;
+    wxMacProcessNotifierAndPendingEvents() ;
 
-    gs_inYield = FALSE;
-    
-    return TRUE;
-}
+    s_inYield = FALSE;
 
-// Yield to incoming messages; but fail silently if recursion is detected.
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-        
-    return wxYield();
+    return TRUE;
 }
 
 // platform specifics
 
 void wxApp::MacSuspend( bool convertClipboard )
 {
-       // we have to deactive the window manually
-       
-       wxWindow* window = GetTopWindow() ;
-       if ( window )
-               window->MacActivate( MacGetCurrentEvent() , false ) ;
-               
-               s_lastMouseDown = 0 ;
-               if( convertClipboard )
-               {
-                       MacConvertPrivateToPublicScrap() ;
-               }
-
-               UMAHideFloatingWindows() ;
+    // we have to deactive the window manually
+
+    wxWindow* window = GetTopWindow() ;
+    if ( window )
+        window->MacActivate( MacGetCurrentEvent() , false ) ;
+
+        s_lastMouseDown = 0 ;
+        if( convertClipboard )
+        {
+            MacConvertPrivateToPublicScrap() ;
+        }
+
+        UMAHideFloatingWindows() ;
 }
 
 void wxApp::MacResume( bool convertClipboard )
 {
-               s_lastMouseDown = 0 ;
-               if( convertClipboard )
-               {
-                       MacConvertPublicToPrivateScrap() ;
-               }
+        s_lastMouseDown = 0 ;
+        if( convertClipboard )
+        {
+            MacConvertPublicToPrivateScrap() ;
+        }
 
-               UMAShowFloatingWindows() ;
+        UMAShowFloatingWindows() ;
 }
 
 void wxApp::MacConvertPrivateToPublicScrap()
@@ -1006,723 +1002,723 @@ void wxApp::MacDoOneEvent()
 {
   EventRecord event ;
 
-       long sleepTime = 1 ; // GetCaretTime() / 4 ;
+    long sleepTime = 1 ; // GetCaretTime() / 4 ;
 
-       if (WaitNextEvent(everyEvent, &event,sleepTime, s_macCursorRgn))
-       {
+    if (WaitNextEvent(everyEvent, &event,sleepTime, s_macCursorRgn))
+    {
     MacHandleOneEvent( &event );
-       }
-       else
-       {
-               // idlers
-               WindowPtr window = UMAFrontWindow() ;
-               if ( window )
-                       UMAIdleControls( window ) ;
+    }
+    else
+    {
+        // idlers
+        WindowPtr window = UMAFrontWindow() ;
+        if ( window )
+            UMAIdleControls( window ) ;
 
-               wxTheApp->ProcessIdle() ;
-       }
-       if ( event.what != kHighLevelEvent )
-               SetRectRgn( s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
+        wxTheApp->ProcessIdle() ;
+    }
+    if ( event.what != kHighLevelEvent )
+        SetRectRgn( s_macCursorRgn , event.where.h , event.where.v ,  event.where.h + 1 , event.where.v + 1 ) ;
 
-       // repeaters
+    // repeaters
 
   DeletePendingObjects() ;
-       wxMacProcessNotifierAndPendingEvents() ;
+    wxMacProcessNotifierAndPendingEvents() ;
 }
 
 void wxApp::MacHandleOneEvent( EventRecord *ev )
 {
-       m_macCurrentEvent = ev ;
-
-       wxApp::sm_lastMessageTime = ev->when ;
-
-       switch (ev->what)
-       {
-               case mouseDown:
-                       MacHandleMouseDownEvent( ev ) ;
-                       if ( ev->modifiers & controlKey )
-                               s_lastMouseDown = 2;
-                       else
-                               s_lastMouseDown = 1;
-                       break;
-               case mouseUp:
-                       if ( s_lastMouseDown == 2 )
-                       {
-                               ev->modifiers |= controlKey ;
-                       }
-                       else
-                       {
-                               ev->modifiers &= ~controlKey ;
-                       }
-                       MacHandleMouseUpEvent( ev ) ;
-                       s_lastMouseDown = 0;
-                       break;
-               case activateEvt:
-                       MacHandleActivateEvent( ev ) ;
-                       break;
-               case updateEvt:
-                       MacHandleUpdateEvent( ev ) ;
-                       break;
-               case keyDown:
-               case autoKey:
-                       MacHandleKeyDownEvent( ev ) ;
-                       break;
-               case keyUp:
-                       MacHandleKeyUpEvent( ev ) ;
-                       break;
-               case diskEvt:
-                       MacHandleDiskEvent( ev ) ;
-                       break;
-               case osEvt:
-                       MacHandleOSEvent( ev ) ;
-                       break;
-               case kHighLevelEvent:
-                       MacHandleHighLevelEvent( ev ) ;
-                       break;
-               default:
-                       break;
-       }
-       wxMacProcessNotifierAndPendingEvents() ;
+    m_macCurrentEvent = ev ;
+
+    wxApp::sm_lastMessageTime = ev->when ;
+
+    switch (ev->what)
+    {
+        case mouseDown:
+            MacHandleMouseDownEvent( ev ) ;
+            if ( ev->modifiers & controlKey )
+                s_lastMouseDown = 2;
+            else
+                s_lastMouseDown = 1;
+            break;
+        case mouseUp:
+            if ( s_lastMouseDown == 2 )
+            {
+                ev->modifiers |= controlKey ;
+            }
+            else
+            {
+                ev->modifiers &= ~controlKey ;
+            }
+            MacHandleMouseUpEvent( ev ) ;
+            s_lastMouseDown = 0;
+            break;
+        case activateEvt:
+            MacHandleActivateEvent( ev ) ;
+            break;
+        case updateEvt:
+            MacHandleUpdateEvent( ev ) ;
+            break;
+        case keyDown:
+        case autoKey:
+            MacHandleKeyDownEvent( ev ) ;
+            break;
+        case keyUp:
+            MacHandleKeyUpEvent( ev ) ;
+            break;
+        case diskEvt:
+            MacHandleDiskEvent( ev ) ;
+            break;
+        case osEvt:
+            MacHandleOSEvent( ev ) ;
+            break;
+        case kHighLevelEvent:
+            MacHandleHighLevelEvent( ev ) ;
+            break;
+        default:
+            break;
+    }
+    wxMacProcessNotifierAndPendingEvents() ;
 }
 
 void wxApp::MacHandleHighLevelEvent( EventRecord *ev )
 {
-       ::AEProcessAppleEvent( ev ) ;
+    ::AEProcessAppleEvent( ev ) ;
 }
 
 bool s_macIsInModalLoop = false ;
 
 void wxApp::MacHandleMouseDownEvent( EventRecord *ev )
 {
-       wxToolTip::RemoveToolTips() ;
+    wxToolTip::RemoveToolTips() ;
 
-       WindowRef window;
-       WindowRef frontWindow = UMAFrontNonFloatingWindow() ;
-       WindowAttributes frontWindowAttributes = NULL ;
-       if ( frontWindow )
-               UMAGetWindowAttributes( frontWindow , &frontWindowAttributes ) ;
+    WindowRef window;
+    WindowRef frontWindow = UMAFrontNonFloatingWindow() ;
+    WindowAttributes frontWindowAttributes = NULL ;
+    if ( frontWindow )
+        UMAGetWindowAttributes( frontWindow , &frontWindowAttributes ) ;
 
-       short windowPart = ::FindWindow(ev->where, &window);
-       wxWindow* win = wxFindWinFromMacWindow( window ) ;
+    short windowPart = ::FindWindow(ev->where, &window);
+    wxWindow* win = wxFindWinFromMacWindow( window ) ;
     if ( wxPendingDelete.Member(win) )
         return ;
 
-       BitMap screenBits;
-       GetQDGlobalsScreenBits( &screenBits );
-
-       switch (windowPart)
-       {
-               case inMenuBar :
-                       if ( s_macIsInModalLoop )
-                       {
-                               SysBeep ( 30 ) ;
-                       }
-                       else
-                       {
-                               UInt32 menuresult = MenuSelect(ev->where) ;
-                               MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) );
-                               s_lastMouseDown = 0;
-                       }
-                       break ;
+    BitMap screenBits;
+    GetQDGlobalsScreenBits( &screenBits );
+
+    switch (windowPart)
+    {
+        case inMenuBar :
+            if ( s_macIsInModalLoop )
+            {
+                SysBeep ( 30 ) ;
+            }
+            else
+            {
+                UInt32 menuresult = MenuSelect(ev->where) ;
+                MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) );
+                s_lastMouseDown = 0;
+            }
+            break ;
 #if !TARGET_CARBON
-               case inSysWindow :
-                       SystemClick( ev , window ) ;
-                       s_lastMouseDown = 0;
-                       break ;
+        case inSysWindow :
+            SystemClick( ev , window ) ;
+            s_lastMouseDown = 0;
+            break ;
 #endif
-               case inDrag :
-                       if ( window != frontWindow && s_macIsInModalLoop && !(ev->modifiers & cmdKey ) )
-                       {
-                               SysBeep ( 30 ) ;
-                       }
-                       else
-                       {
-                               DragWindow(window, ev->where, &screenBits.bounds);
-                               if (win)
-                               {
-                                       GrafPtr port ;
-                                       GetPort( &port ) ;
-                                       Point pt = { 0, 0 } ;
-                                       #if TARGET_CARBON
-                                       SetPort( GetWindowPort(window) ) ;
-                                       #else
-                                       SetPort( (window) ) ;
-                                       #endif
-                                       SetOrigin( 0 , 0 ) ;
-                                       LocalToGlobal( &pt ) ;
-                                       SetPort( port ) ;
-                                               win->SetSize( pt.h , pt.v , -1 ,
-                                                       -1 , wxSIZE_USE_EXISTING);
-                               }
-                               s_lastMouseDown = 0;
-                       }
-                       break ;
-               case inGoAway:
-                       if (TrackGoAway(window, ev->where))
-                       {
-                               if ( win )
-                                       win->Close() ;
-                       }
-                       s_lastMouseDown = 0;
-                       break;
-               case inGrow:
-                 {
-                               int growResult = GrowWindow(window , ev->where, &screenBits.bounds);
-                               if (growResult != 0)
-                               {
-                                       int newWidth = LoWord(growResult);
-                                       int newHeight = HiWord(growResult);
-                                       int oldWidth, oldHeight;
-
-
-                                       if (win)
-                                       {
-                                               win->GetSize(&oldWidth, &oldHeight);
-                                               if (newWidth == 0)
-                                                       newWidth = oldWidth;
-                                               if (newHeight == 0)
-                                                       newHeight = oldHeight;
-                                               win->SetSize( -1, -1, newWidth, newHeight, wxSIZE_USE_EXISTING);
-                                       }
-                               }
-                               s_lastMouseDown = 0;
-                 }
-                       break;
-               case inZoomIn:
-               case inZoomOut:
-                               if (TrackBox(window, ev->where, windowPart))
-                               {
-                                       // TODO setup size event
-                                       ZoomWindow( window , windowPart , false ) ;
-                                       if (win)
-                                       {
-                                               Rect tempRect ;
-                                               
-                                               GetWindowPortBounds(window, &tempRect ) ;
-                                               win->SetSize( -1, -1, tempRect.right-tempRect.left ,
-                                                       tempRect.bottom-tempRect.top, wxSIZE_USE_EXISTING);
-                                       }
-                               }
-                       s_lastMouseDown = 0;
-                       break;
-               case inCollapseBox :
-                               // TODO setup size event
-                       s_lastMouseDown = 0;
-                       break ;
-
-               case inContent :
-                               {
-                                       GrafPtr port ;
-                                       GetPort( &port ) ;
-                                       #if TARGET_CARBON
-                                       SetPort( GetWindowPort(window) ) ;
-                                       #else
-                                       SetPort( (window) ) ;
-                                       #endif
-                                       SetOrigin( 0 , 0 ) ;
-                                       SetPort( port ) ;
-                               }
-                               if ( window != frontWindow && wxTheApp->s_captureWindow == NULL )
-                               {
-                                       if ( s_macIsInModalLoop )
-                                       {
-                                               SysBeep ( 30 ) ;
-                                       }
-                                       else if ( UMAIsWindowFloating( window ) )
-                                       {
-                                               if ( win )
-                                                       win->MacMouseDown( ev , windowPart ) ;
-                                       }
-                                       else
-                                       {
-                                               if ( win )
-                                                       win->MacMouseDown( ev , windowPart ) ;
-                                               UMASelectWindow( window ) ;
-                                       }
-                               }
-                               else
-                               {
-                                       if ( win )
-                                               win->MacMouseDown( ev , windowPart ) ;
-                               }
-                       break ;
-
-               default:
-                       break;
-       }
+        case inDrag :
+            if ( window != frontWindow && s_macIsInModalLoop && !(ev->modifiers & cmdKey ) )
+            {
+                SysBeep ( 30 ) ;
+            }
+            else
+            {
+                DragWindow(window, ev->where, &screenBits.bounds);
+                if (win)
+                {
+                    GrafPtr port ;
+                    GetPort( &port ) ;
+                    Point pt = { 0, 0 } ;
+                    #if TARGET_CARBON
+                    SetPort( GetWindowPort(window) ) ;
+                    #else
+                    SetPort( (window) ) ;
+                    #endif
+                    SetOrigin( 0 , 0 ) ;
+                    LocalToGlobal( &pt ) ;
+                    SetPort( port ) ;
+                        win->SetSize( pt.h , pt.v , -1 ,
+                            -1 , wxSIZE_USE_EXISTING);
+                }
+                s_lastMouseDown = 0;
+            }
+            break ;
+        case inGoAway:
+            if (TrackGoAway(window, ev->where))
+            {
+                if ( win )
+                    win->Close() ;
+            }
+            s_lastMouseDown = 0;
+            break;
+        case inGrow:
+          {
+                int growResult = GrowWindow(window , ev->where, &screenBits.bounds);
+                if (growResult != 0)
+                {
+                    int newWidth = LoWord(growResult);
+                    int newHeight = HiWord(growResult);
+                    int oldWidth, oldHeight;
+
+
+                    if (win)
+                    {
+                        win->GetSize(&oldWidth, &oldHeight);
+                        if (newWidth == 0)
+                            newWidth = oldWidth;
+                        if (newHeight == 0)
+                            newHeight = oldHeight;
+                        win->SetSize( -1, -1, newWidth, newHeight, wxSIZE_USE_EXISTING);
+                    }
+                }
+                s_lastMouseDown = 0;
+          }
+            break;
+        case inZoomIn:
+        case inZoomOut:
+                if (TrackBox(window, ev->where, windowPart))
+                {
+                    // TODO setup size event
+                    ZoomWindow( window , windowPart , false ) ;
+                    if (win)
+                    {
+                        Rect tempRect ;
+
+                        GetWindowPortBounds(window, &tempRect ) ;
+                        win->SetSize( -1, -1, tempRect.right-tempRect.left ,
+                            tempRect.bottom-tempRect.top, wxSIZE_USE_EXISTING);
+                    }
+                }
+            s_lastMouseDown = 0;
+            break;
+        case inCollapseBox :
+                // TODO setup size event
+            s_lastMouseDown = 0;
+            break ;
+
+        case inContent :
+                {
+                    GrafPtr port ;
+                    GetPort( &port ) ;
+                    #if TARGET_CARBON
+                    SetPort( GetWindowPort(window) ) ;
+                    #else
+                    SetPort( (window) ) ;
+                    #endif
+                    SetOrigin( 0 , 0 ) ;
+                    SetPort( port ) ;
+                }
+                if ( window != frontWindow && wxTheApp->s_captureWindow == NULL )
+                {
+                    if ( s_macIsInModalLoop )
+                    {
+                        SysBeep ( 30 ) ;
+                    }
+                    else if ( UMAIsWindowFloating( window ) )
+                    {
+                        if ( win )
+                            win->MacMouseDown( ev , windowPart ) ;
+                    }
+                    else
+                    {
+                        if ( win )
+                            win->MacMouseDown( ev , windowPart ) ;
+                        UMASelectWindow( window ) ;
+                    }
+                }
+                else
+                {
+                    if ( win )
+                        win->MacMouseDown( ev , windowPart ) ;
+                }
+            break ;
+
+        default:
+            break;
+    }
 }
 
 void wxApp::MacHandleMouseUpEvent( EventRecord *ev )
 {
-       WindowRef window;
-
-       short windowPart = ::FindWindow(ev->where, &window);
-
-       switch (windowPart)
-       {
-               case inMenuBar :
-                       break ;
-               case inSysWindow :
-                       break ;
-               default:
-                       {
-                               wxWindow* win = wxFindWinFromMacWindow( window ) ;
-                               if ( win )
-                                       win->MacMouseUp( ev , windowPart ) ;
-                       }
-                       break;
-       }
+    WindowRef window;
+
+    short windowPart = ::FindWindow(ev->where, &window);
+
+    switch (windowPart)
+    {
+        case inMenuBar :
+            break ;
+        case inSysWindow :
+            break ;
+        default:
+            {
+                wxWindow* win = wxFindWinFromMacWindow( window ) ;
+                if ( win )
+                    win->MacMouseUp( ev , windowPart ) ;
+            }
+            break;
+    }
 }
 
 long wxMacTranslateKey(unsigned char key, unsigned char code)
 {
-       long retval = key ;
+    long retval = key ;
     switch (key)
     {
-       case 0x01 :
-                               retval = WXK_HOME;
-                 break;
-       case 0x03 :
-                               retval = WXK_RETURN;
-                 break;
-       case 0x04 :
-                               retval = WXK_END;
-                 break;
-       case 0x05 :
-                               retval = WXK_HELP;
-                 break;
-       case 0x08 :
-                               retval = WXK_BACK;
-                 break;
-       case 0x09 :
-                               retval = WXK_TAB;
-                 break;
-       case 0x0b :
-                               retval = WXK_PAGEUP;
-                 break;
-       case 0x0c :
-                               retval = WXK_PAGEDOWN;
-                 break;
-       case 0x0d :
-                               retval = WXK_RETURN;
-                 break;
-                       case 0x10 :
-                       {
-                               switch( code )
-                               {
-                                       case 0x7a :
-                                               retval = WXK_F1 ;
-                                               break;
-                                       case 0x78 :
-                                               retval = WXK_F2 ;
-                                               break;
-                                       case 0x63 :
-                                               retval = WXK_F3 ;
-                                               break;
-                                       case 0x76 :
-                                               retval = WXK_F4 ;
-                                               break;
-                                       case 0x60 :
-                                               retval = WXK_F5 ;
-                                               break;
-                                       case 0x61 :
-                                               retval = WXK_F6 ;
-                                               break;
-                                       case 0x62:
-                                               retval = WXK_F7 ;
-                                               break;
-                                       case 0x64 :
-                                               retval = WXK_F8 ;
-                                               break;
-                                       case 0x65 :
-                                               retval = WXK_F9 ;
-                                               break;
-                                       case 0x6D :
-                                               retval = WXK_F10 ;
-                                               break;
-                                       case 0x67 :
-                                               retval = WXK_F11 ;
-                                               break;
-                                       case 0x6F :
-                                               retval = WXK_F12 ;
-                                               break;
-                                       case 0x69 :
-                                               retval = WXK_F13 ;
-                                               break;
-                                       case 0x6B :
-                                               retval = WXK_F14 ;
-                                               break;
-                                       case 0x71 :
-                                               retval = WXK_F15 ;
-                                               break;
-                               }
-                       }
-                       break ;
-                       case 0x1b :
-                               retval = WXK_ESCAPE ;
-                       break ;
-                       case 0x1c :
-                               retval = WXK_LEFT ;
-                       break ;
-                       case 0x1d :
-                               retval = WXK_RIGHT ;
-                       break ;
-                       case 0x1e :
-                               retval = WXK_UP ;
-                       break ;
-                       case 0x1f :
-                               retval = WXK_DOWN ;
-                       break ;
-                       case 0x7F :
-                               retval = WXK_DELETE ;
-                       default:
-                       break ;
-       } // end switch
-
-       return retval;
+        case 0x01 :
+                 retval = WXK_HOME;
+          break;
+        case 0x03 :
+                 retval = WXK_RETURN;
+          break;
+        case 0x04 :
+                 retval = WXK_END;
+          break;
+        case 0x05 :
+                 retval = WXK_HELP;
+          break;
+        case 0x08 :
+                 retval = WXK_BACK;
+          break;
+        case 0x09 :
+                 retval = WXK_TAB;
+          break;
+        case 0x0b :
+                 retval = WXK_PAGEUP;
+          break;
+        case 0x0c :
+                 retval = WXK_PAGEDOWN;
+          break;
+        case 0x0d :
+                 retval = WXK_RETURN;
+          break;
+            case 0x10 :
+            {
+                switch( code )
+                {
+                    case 0x7a :
+                        retval = WXK_F1 ;
+                        break;
+                    case 0x78 :
+                        retval = WXK_F2 ;
+                        break;
+                    case 0x63 :
+                        retval = WXK_F3 ;
+                        break;
+                    case 0x76 :
+                        retval = WXK_F4 ;
+                        break;
+                    case 0x60 :
+                        retval = WXK_F5 ;
+                        break;
+                    case 0x61 :
+                        retval = WXK_F6 ;
+                        break;
+                    case 0x62:
+                        retval = WXK_F7 ;
+                        break;
+                    case 0x64 :
+                        retval = WXK_F8 ;
+                        break;
+                    case 0x65 :
+                        retval = WXK_F9 ;
+                        break;
+                    case 0x6D :
+                        retval = WXK_F10 ;
+                        break;
+                    case 0x67 :
+                        retval = WXK_F11 ;
+                        break;
+                    case 0x6F :
+                        retval = WXK_F12 ;
+                        break;
+                    case 0x69 :
+                        retval = WXK_F13 ;
+                        break;
+                    case 0x6B :
+                        retval = WXK_F14 ;
+                        break;
+                    case 0x71 :
+                        retval = WXK_F15 ;
+                        break;
+                }
+            }
+            break ;
+            case 0x1b :
+                retval = WXK_ESCAPE ;
+            break ;
+            case 0x1c :
+                retval = WXK_LEFT ;
+            break ;
+            case 0x1d :
+                retval = WXK_RIGHT ;
+            break ;
+            case 0x1e :
+                retval = WXK_UP ;
+            break ;
+            case 0x1f :
+                retval = WXK_DOWN ;
+            break ;
+            case 0x7F :
+                retval = WXK_DELETE ;
+             default:
+            break ;
+     } // end switch
+
+    return retval;
 }
 
 void wxApp::MacHandleKeyDownEvent( EventRecord *ev )
 {
-       wxToolTip::RemoveToolTips() ;
-       
-       UInt32 menuresult = UMAMenuEvent(ev) ;
-       if ( HiWord( menuresult ) )
-       {
-               if ( !s_macIsInModalLoop )
-               MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) ) ;
-       }
-       else
-       {
-               short keycode ;
-               short keychar ;
-               keychar = short(ev->message & charCodeMask);
-               keycode = short(ev->message & keyCodeMask) >> 8 ;
-
-               wxWindow* focus = wxWindow::FindFocus() ;
-               if ( focus )
-               {
-                       long keyval = wxMacTranslateKey(keychar, keycode) ;
-                       
-                       wxKeyEvent event(wxEVT_KEY_DOWN);
-                       event.m_shiftDown = ev->modifiers & shiftKey;
-                       event.m_controlDown = ev->modifiers & controlKey;
-                       event.m_altDown = ev->modifiers & optionKey;
-                       event.m_metaDown = ev->modifiers & cmdKey;
-                       event.m_keyCode = keyval;
-                       event.m_x = ev->where.h;
-                       event.m_y = ev->where.v;
-                       event.m_timeStamp = ev->when;
-                       event.SetEventObject(focus);
-                       bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
-                       if ( !handled )
-                       {
-                               #if wxUSE_ACCEL
-                           if (!handled)
-                           {
-                               wxWindow *ancestor = focus;
-                               /*
-                               while (ancestor)
-                               {
-                                   int command = ancestor->GetAcceleratorTable()->GetCommand( event );
-                                   if (command != -1)
-                                   {
-                                       wxCommandEvent command_event( wxEVT_COMMAND_MENU_SELECTED, command );
-                                       handled = ancestor->GetEventHandler()->ProcessEvent( command_event );
-                                       break;
-                                   }
-                                   if (ancestor->m_isFrame)
-                                       break;
-                                   ancestor = ancestor->GetParent();
-                               }
-                               */
-                           }
-                               #endif // wxUSE_ACCEL
-                       }
-                       if (!handled)
-                       {
-                               wxKeyEvent event(wxEVT_CHAR);
-                               event.m_shiftDown = ev->modifiers & shiftKey;
-                               event.m_controlDown = ev->modifiers & controlKey;
-                               event.m_altDown = ev->modifiers & optionKey;
-                               event.m_metaDown = ev->modifiers & cmdKey;
-                               event.m_keyCode = keyval;
-                               event.m_x = ev->where.h;
-                               event.m_y = ev->where.v;
-                               event.m_timeStamp = ev->when;
-                               event.SetEventObject(focus);
-                               handled = focus->GetEventHandler()->ProcessEvent( event ) ;
-                       }
-                       if ( !handled &&
-                        (keyval == WXK_TAB) &&
-                        (!focus->HasFlag(wxTE_PROCESS_TAB)) &&
-                        (focus->GetParent()) &&
-                        (focus->GetParent()->HasFlag( wxTAB_TRAVERSAL)) )
-                   {
-                       wxNavigationKeyEvent new_event;
-                       new_event.SetEventObject( focus );
-                       new_event.SetDirection( !event.ShiftDown() );
-                       /* CTRL-TAB changes the (parent) window, i.e. switch notebook page */
-                       new_event.SetWindowChange( event.ControlDown() );
-                       new_event.SetCurrentFocus( focus );
-                       handled = focus->GetEventHandler()->ProcessEvent( new_event );
-                   }
-                   /* generate wxID_CANCEL if command-. or <esc> has been pressed (typically in dialogs) */
-                   if ( (!handled) &&
-                        (keyval == '.' && event.ControlDown() ) )
-                   {
-                       wxCommandEvent new_event(wxEVT_COMMAND_BUTTON_CLICKED,wxID_CANCEL);
-                       new_event.SetEventObject( focus );
-                       handled = focus->GetEventHandler()->ProcessEvent( new_event );
-                   }
-               }
-       }
+    wxToolTip::RemoveToolTips() ;
+
+    UInt32 menuresult = UMAMenuEvent(ev) ;
+    if ( HiWord( menuresult ) )
+    {
+        if ( !s_macIsInModalLoop )
+        MacHandleMenuSelect( HiWord( menuresult ) , LoWord( menuresult ) ) ;
+    }
+    else
+    {
+        short keycode ;
+        short keychar ;
+        keychar = short(ev->message & charCodeMask);
+        keycode = short(ev->message & keyCodeMask) >> 8 ;
+
+        wxWindow* focus = wxWindow::FindFocus() ;
+        if ( focus )
+        {
+            long keyval = wxMacTranslateKey(keychar, keycode) ;
+
+            wxKeyEvent event(wxEVT_KEY_DOWN);
+            event.m_shiftDown = ev->modifiers & shiftKey;
+            event.m_controlDown = ev->modifiers & controlKey;
+            event.m_altDown = ev->modifiers & optionKey;
+            event.m_metaDown = ev->modifiers & cmdKey;
+            event.m_keyCode = keyval;
+            event.m_x = ev->where.h;
+            event.m_y = ev->where.v;
+            event.m_timeStamp = ev->when;
+            event.SetEventObject(focus);
+            bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
+            if ( !handled )
+            {
+                #if wxUSE_ACCEL
+                if (!handled)
+                {
+                    wxWindow *ancestor = focus;
+                    /*
+                    while (ancestor)
+                    {
+                        int command = ancestor->GetAcceleratorTable()->GetCommand( event );
+                        if (command != -1)
+                        {
+                            wxCommandEvent command_event( wxEVT_COMMAND_MENU_SELECTED, command );
+                            handled = ancestor->GetEventHandler()->ProcessEvent( command_event );
+                            break;
+                        }
+                        if (ancestor->m_isFrame)
+                            break;
+                        ancestor = ancestor->GetParent();
+                    }
+                    */
+                }
+                #endif // wxUSE_ACCEL
+            }
+            if (!handled)
+            {
+                wxKeyEvent event(wxEVT_CHAR);
+                event.m_shiftDown = ev->modifiers & shiftKey;
+                event.m_controlDown = ev->modifiers & controlKey;
+                event.m_altDown = ev->modifiers & optionKey;
+                event.m_metaDown = ev->modifiers & cmdKey;
+                event.m_keyCode = keyval;
+                event.m_x = ev->where.h;
+                event.m_y = ev->where.v;
+                event.m_timeStamp = ev->when;
+                event.SetEventObject(focus);
+                handled = focus->GetEventHandler()->ProcessEvent( event ) ;
+            }
+            if ( !handled &&
+                 (keyval == WXK_TAB) &&
+                 (!focus->HasFlag(wxTE_PROCESS_TAB)) &&
+                 (focus->GetParent()) &&
+                 (focus->GetParent()->HasFlag( wxTAB_TRAVERSAL)) )
+            {
+                wxNavigationKeyEvent new_event;
+                new_event.SetEventObject( focus );
+                new_event.SetDirection( !event.ShiftDown() );
+                /* CTRL-TAB changes the (parent) window, i.e. switch notebook page */
+                new_event.SetWindowChange( event.ControlDown() );
+                new_event.SetCurrentFocus( focus );
+                handled = focus->GetEventHandler()->ProcessEvent( new_event );
+            }
+            /* generate wxID_CANCEL if command-. or <esc> has been pressed (typically in dialogs) */
+            if ( (!handled) &&
+                 (keyval == '.' && event.ControlDown() ) )
+            {
+                wxCommandEvent new_event(wxEVT_COMMAND_BUTTON_CLICKED,wxID_CANCEL);
+                new_event.SetEventObject( focus );
+                handled = focus->GetEventHandler()->ProcessEvent( new_event );
+            }
+        }
+    }
 }
 
 void wxApp::MacHandleKeyUpEvent( EventRecord *ev )
 {
-       wxToolTip::RemoveToolTips() ;
-       
-       UInt32 menuresult = UMAMenuEvent(ev) ;
-       if ( HiWord( menuresult ) )
-       {
-       }
-       else
-       {
-               short keycode ;
-               short keychar ;
-               keychar = short(ev->message & charCodeMask);
-               keycode = short(ev->message & keyCodeMask) >> 8 ;
-
-               wxWindow* focus = wxWindow::FindFocus() ;
-               if ( focus )
-               {
-                       long keyval = wxMacTranslateKey(keychar, keycode) ;
-                       
-                       wxKeyEvent event(wxEVT_KEY_UP);
-                       event.m_shiftDown = ev->modifiers & shiftKey;
-                       event.m_controlDown = ev->modifiers & controlKey;
-                       event.m_altDown = ev->modifiers & optionKey;
-                       event.m_metaDown = ev->modifiers & cmdKey;
-                       event.m_keyCode = keyval;
-                       event.m_x = ev->where.h;
-                       event.m_y = ev->where.v;
-                       event.m_timeStamp = ev->when;
-                       event.SetEventObject(focus);
-                       bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
-               }
-       }
+    wxToolTip::RemoveToolTips() ;
+
+    UInt32 menuresult = UMAMenuEvent(ev) ;
+    if ( HiWord( menuresult ) )
+    {
+    }
+    else
+    {
+        short keycode ;
+        short keychar ;
+        keychar = short(ev->message & charCodeMask);
+        keycode = short(ev->message & keyCodeMask) >> 8 ;
+
+        wxWindow* focus = wxWindow::FindFocus() ;
+        if ( focus )
+        {
+            long keyval = wxMacTranslateKey(keychar, keycode) ;
+
+            wxKeyEvent event(wxEVT_KEY_UP);
+            event.m_shiftDown = ev->modifiers & shiftKey;
+            event.m_controlDown = ev->modifiers & controlKey;
+            event.m_altDown = ev->modifiers & optionKey;
+            event.m_metaDown = ev->modifiers & cmdKey;
+            event.m_keyCode = keyval;
+            event.m_x = ev->where.h;
+            event.m_y = ev->where.v;
+            event.m_timeStamp = ev->when;
+            event.SetEventObject(focus);
+            bool handled = focus->GetEventHandler()->ProcessEvent( event ) ;
+        }
+    }
 }
 
 void wxApp::MacHandleActivateEvent( EventRecord *ev )
 {
-       WindowRef window = (WindowRef) ev->message ;
-       if ( window )
-       {
-               bool activate = (ev->modifiers & activeFlag ) ;
-               WindowClass wclass ;
-               UMAGetWindowClass ( window , &wclass ) ;
-               if ( wclass == kFloatingWindowClass )
-               {
-                       // if it is a floater we activate/deactivate the front non-floating window instead
-                       window = UMAFrontNonFloatingWindow() ;
-               }
-               wxWindow* win = wxFindWinFromMacWindow( window ) ;
-               if ( win )
-                       win->MacActivate( ev , activate ) ;
-       }
+    WindowRef window = (WindowRef) ev->message ;
+    if ( window )
+    {
+        bool activate = (ev->modifiers & activeFlag ) ;
+        WindowClass wclass ;
+        UMAGetWindowClass ( window , &wclass ) ;
+        if ( wclass == kFloatingWindowClass )
+        {
+            // if it is a floater we activate/deactivate the front non-floating window instead
+            window = UMAFrontNonFloatingWindow() ;
+        }
+        wxWindow* win = wxFindWinFromMacWindow( window ) ;
+        if ( win )
+            win->MacActivate( ev , activate ) ;
+    }
 }
 
 void wxApp::MacHandleUpdateEvent( EventRecord *ev )
 {
-       WindowRef window = (WindowRef) ev->message ;
-       wxWindow * win = wxFindWinFromMacWindow( window ) ;
-       if ( win )
-       {
+    WindowRef window = (WindowRef) ev->message ;
+    wxWindow * win = wxFindWinFromMacWindow( window ) ;
+    if ( win )
+    {
         if ( !wxPendingDelete.Member(win) )
-                       win->MacUpdate( ev ) ;
-       }
-       else
-       {
-               // since there is no way of telling this foreign window to update itself
-               // we have to invalidate the update region otherwise we keep getting the same
-               // event over and over again
-               BeginUpdate( window ) ;
-               EndUpdate( window ) ;
-       }
+            win->MacUpdate( ev ) ;
+    }
+    else
+    {
+        // since there is no way of telling this foreign window to update itself
+        // we have to invalidate the update region otherwise we keep getting the same
+        // event over and over again
+        BeginUpdate( window ) ;
+        EndUpdate( window ) ;
+    }
 }
 
 void wxApp::MacHandleDiskEvent( EventRecord *ev )
 {
-       if ( HiWord( ev->message ) != noErr )
+    if ( HiWord( ev->message ) != noErr )
   {
  #if !TARGET_CARBON
-               OSErr err ;
-               Point point ;
-               SetPt( &point , 100 , 100 ) ;
+        OSErr err ;
+        Point point ;
+         SetPt( &point , 100 , 100 ) ;
 
-               err = DIBadMount( point , ev->message ) ;
-               wxASSERT( err == noErr ) ;
+          err = DIBadMount( point , ev->message ) ;
+        wxASSERT( err == noErr ) ;
 #endif
-       }
+    }
 }
 
 void wxApp::MacHandleOSEvent( EventRecord *ev )
 {
-       switch( ( ev->message & osEvtMessageMask ) >> 24 )
-       {
-               case suspendResumeMessage :
-                       {
-                               bool isResuming = ev->message & resumeFlag ;
+    switch( ( ev->message & osEvtMessageMask ) >> 24 )
+    {
+        case suspendResumeMessage :
+            {
+                bool isResuming = ev->message & resumeFlag ;
 #if !TARGET_CARBON
-                               bool convertClipboard = ev->message & convertClipboardFlag ;
+                bool convertClipboard = ev->message & convertClipboardFlag ;
 #else
-                               bool convertClipboard = false;
+                bool convertClipboard = false;
 #endif
-                               bool doesActivate = UMAGetProcessModeDoesActivateOnFGSwitch() ;
-                               if ( isResuming )
-                               {
-                                       WindowRef oldFrontWindow = NULL ;
-                                       WindowRef newFrontWindow = NULL ;
-
-                                       // in case we don't take care of activating ourselves, we have to synchronize
-                                       // our idea of the active window with the process manager's - which it already activated
-
-                                       if ( !doesActivate )
-                                               oldFrontWindow = UMAFrontNonFloatingWindow() ;
-
-                                       MacResume( convertClipboard ) ;
-
-                                       newFrontWindow = UMAFrontNonFloatingWindow() ;
-
-                                       if ( oldFrontWindow )
-                                       {
-                                               wxWindow* win = wxFindWinFromMacWindow( oldFrontWindow ) ;
-                                               if ( win )
-                                                       win->MacActivate( ev , false ) ;
-                                       }
-                                       if ( newFrontWindow )
-                                       {
-                                               wxWindow* win = wxFindWinFromMacWindow( newFrontWindow ) ;
-                                               if ( win )
-                                                       win->MacActivate( ev , true ) ;
-                                       }
-                               }
-                               else
-                               {
-                                       MacSuspend( convertClipboard ) ;
-
-                                       // in case this suspending did close an active window, another one might
-                                       // have surfaced -> lets deactivate that one
-
-                                       WindowRef newActiveWindow = UMAGetActiveNonFloatingWindow() ;
-                                       if ( newActiveWindow )
-                                       {
-                                               wxWindow* win = wxFindWinFromMacWindow( newActiveWindow ) ;
-                                               if ( win )
-                                                       win->MacActivate( ev , false ) ;
-                                       }
-                               }
-                       }
-                       break ;
-               case mouseMovedMessage :
-                       {
-                               WindowRef window;
-
-                               wxWindow* currentMouseWindow = NULL ;
-
-                               wxWindow::MacGetWindowFromPoint( wxPoint( ev->where.h , ev->where.v ) ,
-                                                                                                &currentMouseWindow ) ;
-
-                               if ( currentMouseWindow != wxWindow::s_lastMouseWindow )
-                               {
-                                       wxMouseEvent event ;
-
-                                       bool isDown = !(ev->modifiers & btnState) ; // 1 is for up
-                                       bool controlDown = ev->modifiers & controlKey ; // for simulating right mouse
-
-                                       event.m_leftDown = isDown && !controlDown;
-                                       event.m_middleDown = FALSE;
-                                       event.m_rightDown = isDown && controlDown;
-                                       event.m_shiftDown = ev->modifiers & shiftKey;
-                                       event.m_controlDown = ev->modifiers & controlKey;
-                                       event.m_altDown = ev->modifiers & optionKey;
-                                       event.m_metaDown = ev->modifiers & cmdKey;
-                                       event.m_x = ev->where.h;
-                                       event.m_y = ev->where.v;
-                                       event.m_timeStamp = ev->when;
-                                       event.SetEventObject(this);
-
-                                       if ( wxWindow::s_lastMouseWindow )
-                                       {
-                                               wxMouseEvent eventleave(event ) ;
-                                               eventleave.SetEventType( wxEVT_LEAVE_WINDOW ) ;
-                                               wxWindow::s_lastMouseWindow->GetEventHandler()->ProcessEvent(eventleave);
-                                       }
-                                       if ( currentMouseWindow )
-                                       {
-                                               wxMouseEvent evententer(event ) ;
-                                               evententer.SetEventType( wxEVT_ENTER_WINDOW ) ;
-                                               currentMouseWindow->GetEventHandler()->ProcessEvent(evententer);
-                                       }
-                                       wxWindow::s_lastMouseWindow = currentMouseWindow ;
-                               }
-
-                               short windowPart = ::FindWindow(ev->where, &window);
-
-                               switch (windowPart)
-                               {
-                                       // fixes for setting the cursor back from dominic mazzoni
-                                       case inMenuBar :
-                                           UMAShowArrowCursor();
-                                               break ;
-                                       case inSysWindow :
-                                           UMAShowArrowCursor();
-                                               break ;
-                                       default:
-                                               {
-                                                       if ( s_lastMouseDown == 0 )
-                                                               ev->modifiers |= btnState ;
-
-                                                       wxWindow* win = wxFindWinFromMacWindow( window ) ;
-                                                       if ( win )
-                                                               win->MacMouseMoved( ev , windowPart ) ;
-                                                       else                                       
-                                                       UMAShowArrowCursor();
-
-                                               }
-                                               break;
-                               }
-                       }
-                       break ;
-
-       }
+                bool doesActivate = UMAGetProcessModeDoesActivateOnFGSwitch() ;
+                if ( isResuming )
+                {
+                    WindowRef oldFrontWindow = NULL ;
+                    WindowRef newFrontWindow = NULL ;
+
+                    // in case we don't take care of activating ourselves, we have to synchronize
+                    // our idea of the active window with the process manager's - which it already activated
+
+                    if ( !doesActivate )
+                        oldFrontWindow = UMAFrontNonFloatingWindow() ;
+
+                    MacResume( convertClipboard ) ;
+
+                    newFrontWindow = UMAFrontNonFloatingWindow() ;
+
+                    if ( oldFrontWindow )
+                    {
+                        wxWindow* win = wxFindWinFromMacWindow( oldFrontWindow ) ;
+                        if ( win )
+                            win->MacActivate( ev , false ) ;
+                    }
+                    if ( newFrontWindow )
+                    {
+                        wxWindow* win = wxFindWinFromMacWindow( newFrontWindow ) ;
+                        if ( win )
+                            win->MacActivate( ev , true ) ;
+                    }
+                }
+                else
+                {
+                    MacSuspend( convertClipboard ) ;
+
+                    // in case this suspending did close an active window, another one might
+                    // have surfaced -> lets deactivate that one
+
+                    WindowRef newActiveWindow = UMAGetActiveNonFloatingWindow() ;
+                    if ( newActiveWindow )
+                    {
+                        wxWindow* win = wxFindWinFromMacWindow( newActiveWindow ) ;
+                        if ( win )
+                            win->MacActivate( ev , false ) ;
+                    }
+                }
+            }
+            break ;
+        case mouseMovedMessage :
+            {
+                WindowRef window;
+
+                wxWindow* currentMouseWindow = NULL ;
+
+                wxWindow::MacGetWindowFromPoint( wxPoint( ev->where.h , ev->where.v ) ,
+                                                 &currentMouseWindow ) ;
+
+                if ( currentMouseWindow != wxWindow::s_lastMouseWindow )
+                {
+                    wxMouseEvent event ;
+
+                    bool isDown = !(ev->modifiers & btnState) ; // 1 is for up
+                    bool controlDown = ev->modifiers & controlKey ; // for simulating right mouse
+
+                    event.m_leftDown = isDown && !controlDown;
+                    event.m_middleDown = FALSE;
+                    event.m_rightDown = isDown && controlDown;
+                    event.m_shiftDown = ev->modifiers & shiftKey;
+                    event.m_controlDown = ev->modifiers & controlKey;
+                    event.m_altDown = ev->modifiers & optionKey;
+                    event.m_metaDown = ev->modifiers & cmdKey;
+                    event.m_x = ev->where.h;
+                    event.m_y = ev->where.v;
+                    event.m_timeStamp = ev->when;
+                    event.SetEventObject(this);
+
+                    if ( wxWindow::s_lastMouseWindow )
+                    {
+                        wxMouseEvent eventleave(event ) ;
+                        eventleave.SetEventType( wxEVT_LEAVE_WINDOW ) ;
+                        wxWindow::s_lastMouseWindow->GetEventHandler()->ProcessEvent(eventleave);
+                    }
+                    if ( currentMouseWindow )
+                    {
+                        wxMouseEvent evententer(event ) ;
+                        evententer.SetEventType( wxEVT_ENTER_WINDOW ) ;
+                        currentMouseWindow->GetEventHandler()->ProcessEvent(evententer);
+                    }
+                    wxWindow::s_lastMouseWindow = currentMouseWindow ;
+                }
+
+                short windowPart = ::FindWindow(ev->where, &window);
+
+                switch (windowPart)
+                {
+                    // fixes for setting the cursor back from dominic mazzoni
+                    case inMenuBar :
+                        UMAShowArrowCursor();
+                        break ;
+                    case inSysWindow :
+                        UMAShowArrowCursor();
+                        break ;
+                    default:
+                        {
+                            if ( s_lastMouseDown == 0 )
+                                ev->modifiers |= btnState ;
+
+                            wxWindow* win = wxFindWinFromMacWindow( window ) ;
+                            if ( win )
+                                win->MacMouseMoved( ev , windowPart ) ;
+                            else
+                                UMAShowArrowCursor();
+
+                        }
+                        break;
+                }
+            }
+            break ;
+
+    }
 }
 
 void wxApp::MacHandleMenuSelect( int macMenuId , int macMenuItemNum )
 {
-       if (macMenuId == 0)
-                return; // no menu item selected
-
-       if (macMenuId == kwxMacAppleMenuId && macMenuItemNum > 1)
-       {
-               #if ! TARGET_CARBON
-               Str255          deskAccessoryName ;
-               GrafPtr         savedPort ;
-
-               GetMenuItemText(GetMenuHandle(kwxMacAppleMenuId), macMenuItemNum, deskAccessoryName);
-               GetPort(&savedPort);
-               OpenDeskAcc(deskAccessoryName);
-               SetPort(savedPort);
-               #endif
-       }
-       else
-       {
-               wxWindow* frontwindow = wxFindWinFromMacWindow( ::FrontWindow() )  ;
-               if ( frontwindow && wxMenuBar::MacGetInstalledMenuBar() )
-                       wxMenuBar::MacGetInstalledMenuBar()->MacMenuSelect( frontwindow->GetEventHandler() , 0 , macMenuId , macMenuItemNum ) ;
-       }
-       HiliteMenu(0);
+    if (macMenuId == 0)
+         return; // no menu item selected
+
+    if (macMenuId == kwxMacAppleMenuId && macMenuItemNum > 1)
+    {
+        #if ! TARGET_CARBON
+        Str255        deskAccessoryName ;
+        GrafPtr        savedPort ;
+
+        GetMenuItemText(GetMenuHandle(kwxMacAppleMenuId), macMenuItemNum, deskAccessoryName);
+        GetPort(&savedPort);
+        OpenDeskAcc(deskAccessoryName);
+        SetPort(savedPort);
+        #endif
+    }
+    else
+    {
+        wxWindow* frontwindow = wxFindWinFromMacWindow( ::FrontWindow() )  ;
+        if ( frontwindow && wxMenuBar::MacGetInstalledMenuBar() )
+            wxMenuBar::MacGetInstalledMenuBar()->MacMenuSelect( frontwindow->GetEventHandler() , 0 , macMenuId , macMenuItemNum ) ;
+    }
+    HiliteMenu(0);
 }
 
 /*
@@ -1741,12 +1737,12 @@ wxApp::macAdjustCursor()
 {
   if (ev->what != kHighLevelEvent)
   {
-       wxWindow* theMacWxFrame = wxFrame::MacFindFrameOrDialog(::FrontWindow());
-       if (theMacWxFrame)
-       {
-         if (!theMacWxFrame->MacAdjustCursor(ev->where))
-               ::SetCursor(&(qd.arrow));
-       }
+    wxWindow* theMacWxFrame = wxFrame::MacFindFrameOrDialog(::FrontWindow());
+    if (theMacWxFrame)
+    {
+        if (!theMacWxFrame->MacAdjustCursor(ev->where))
+        ::SetCursor(&(qd.arrow));
+      }
   }
 }
 */
index fa1fd15f66d814f5f548ab8b5aa2ecf2f55cd137..b552654bc47f09701e9d400655708250493b95a7 100644 (file)
@@ -360,43 +360,43 @@ void wxApp::ProcessXEvent(WXEvent* _event)
                    widget, XtParent(widget));
 #endif // DEBUG
 
-       if (CheckForAccelerator(_event))
-       {
+    if (CheckForAccelerator(_event))
+    {
             // Do nothing! We intercepted and processed the event as an
             // accelerator.
             return;
-       }
+    }
 #if 1
         // It seemed before that this hack was redundant and
         // key down events were being generated by wxCanvasInputEvent.
         // But no longer - why ???
         //
-       else if (CheckForKeyDown(_event))
-       {
+    else if (CheckForKeyDown(_event))
+    {
             // We intercepted and processed the key down event
             return;
-       }
+    }
 #endif
-       else
-       {
+    else
+    {
             XtDispatchEvent(event);
-           return;
-       }
+        return;
+    }
     }
     else if (event->type == KeyRelease)
     {
         // TODO: work out why we still need this !  -michael
         //
         if (CheckForKeyUp(_event))
-       {
-           // We intercepted and processed the key up event
-           return;
-       }
-       else
-       {
-           XtDispatchEvent(event);
-           return;
-       }
+    {
+        // We intercepted and processed the key up event
+        return;
+    }
+    else
+    {
+        XtDispatchEvent(event);
+        return;
+    }
     }
     else if (event->type == PropertyNotify)
     {
@@ -677,20 +677,20 @@ bool wxApp::CheckForKeyDown(WXEvent* event)
     if (xEvent->xany.type == KeyPress)
     {
         Widget widget = XtWindowToWidget((Display*) wxGetDisplay(),
-                                        xEvent->xany.window);
-       wxWindow* win = NULL;
+                     xEvent->xany.window);
+    wxWindow* win = NULL;
 
-       // Find the first wxWindow that corresponds to this event window
-       while (widget && !(win = wxGetWindowFromTable(widget)))
+    // Find the first wxWindow that corresponds to this event window
+    while (widget && !(win = wxGetWindowFromTable(widget)))
             widget = XtParent(widget);
 
-       if (!widget || !win)
+    if (!widget || !win)
             return FALSE;
 
-       wxKeyEvent keyEvent(wxEVT_KEY_DOWN);
-       wxTranslateKeyEvent(keyEvent, win, (Widget) 0, xEvent);
+    wxKeyEvent keyEvent(wxEVT_KEY_DOWN);
+    wxTranslateKeyEvent(keyEvent, win, (Widget) 0, xEvent);
 
-       return win->ProcessEvent( keyEvent );
+    return win->ProcessEvent( keyEvent );
     }
 
     return FALSE;
@@ -702,20 +702,20 @@ bool wxApp::CheckForKeyUp(WXEvent* event)
     if (xEvent->xany.type == KeyRelease)
     {
         Widget widget = XtWindowToWidget((Display*) wxGetDisplay(),
-                                        xEvent->xany.window);
-       wxWindow* win = NULL;
+                         xEvent->xany.window);
+        wxWindow* win = NULL;
 
-       // Find the first wxWindow that corresponds to this event window
-       while (widget && !(win = wxGetWindowFromTable(widget)))
-            widget = XtParent(widget);
+        // Find the first wxWindow that corresponds to this event window
+        while (widget && !(win = wxGetWindowFromTable(widget)))
+                widget = XtParent(widget);
 
-       if (!widget || !win)
-            return FALSE;
+        if (!widget || !win)
+                return FALSE;
 
-       wxKeyEvent keyEvent(wxEVT_KEY_UP);
-       wxTranslateKeyEvent(keyEvent, win, (Widget) 0, xEvent);
+        wxKeyEvent keyEvent(wxEVT_KEY_UP);
+        wxTranslateKeyEvent(keyEvent, win, (Widget) 0, xEvent);
 
-       return win->ProcessEvent( keyEvent );
+        return win->ProcessEvent( keyEvent );
     }
 
     return FALSE;
@@ -737,40 +737,30 @@ void wxExit()
 
 // Yield to other processes
 
-static bool gs_inYield = FALSE;
-
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
-#ifdef __WXDEBUG__    
-    if (gs_inYield)
-        wxFAIL_MSG( wxT("wxYield called recursively" ) );
-#endif
-    
-    gs_inYield = TRUE;
+    bool s_inYield = FALSE;
+
+    if ( s_inYield )
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( wxT("wxYield called recursively" ) );
+        }
+
+        return FALSE;
+    }
+
+    s_inYield = TRUE;
 
     while (wxTheApp && wxTheApp->Pending())
         wxTheApp->Dispatch();
 
-    // VZ: is it the same as this (taken from old wxExecute)?
-#if 0
-    XtAppProcessEvent((XtAppContext) wxTheApp->GetAppContext(), XtIMAll);
-#endif
-
-    gs_inYield = FALSE;
+    s_inYield = FALSE;
 
     return TRUE;
 }
 
-// Yield to incoming messages; but fail silently if recursion is detected.
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-        
-    return wxYield();
-}
-
-
 // TODO use XmGetPixmap (?) to get the really standard icons!
 
 #include "wx/generic/info.xpm"
index 378dccbe3efc0014fa1dfd846af211da7146c228..45250cfe163dcfd64d162d2a6ee82c2b493ca856 100644 (file)
@@ -1435,20 +1435,26 @@ void wxExit()
 
 // Yield to incoming messages
 
-static bool gs_inYield = FALSE;
-
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
+    // MT-FIXME
+    static bool s_inYield = FALSE;
+
     // disable log flushing from here because a call to wxYield() shouldn't
     // normally result in message boxes popping up &c
     wxLog::Suspend();
 
-#ifdef __WXDEBUG__
-    if (gs_inYield)
-        wxFAIL_MSG( wxT("wxYield called recursively" ) );
-#endif
+    if ( s_inYield )
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( wxT("wxYield called recursively" ) );
+        }
 
-    gs_inYield = TRUE;
+        return FALSE;
+    }
+
+    s_inYield = TRUE;
 
     // we don't want to process WM_QUIT from here - it should be processed in
     // the main event loop in order to stop it
@@ -1464,27 +1470,17 @@ bool wxYield()
             break;
     }
 
-    // If they are pending events, we must process them.
-    if (wxTheApp)
-        wxTheApp->ProcessPendingEvents();
+    // if there are pending events, we must process them.
+    ProcessPendingEvents();
 
     // let the logs be flashed again
     wxLog::Resume();
 
-    gs_inYield = FALSE;
+    s_inYield = FALSE;
 
     return TRUE;
 }
 
-// Yield to incoming messages; but fail silently if recursion is detected.
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-
-    return wxYield();
-}
-
 bool wxHandleFatalExceptions(bool doit)
 {
 #if wxUSE_ON_FATAL_EXCEPTION
@@ -1493,9 +1489,9 @@ bool wxHandleFatalExceptions(bool doit)
 
     return TRUE;
 #else
-    wxFAIL_MSG(_T("set wxUSE_ON_FATAL_EXCEPTION to 1 to sue this function"));
-       
-       (void)doit;
+    wxFAIL_MSG(_T("set wxUSE_ON_FATAL_EXCEPTION to 1 to use this function"));
+
+    (void)doit;
     return FALSE;
 #endif
 }
index f95e76b44bfc01db7b06e733498e0d0166c745df..81d2ccbc1b4002397ae7db8d624c50a720b761f9 100644 (file)
@@ -1117,13 +1117,23 @@ void wxExit()
     wxApp::CleanUp();
 } // end of wxExit
 
-static bool gs_inYield = FALSE;
-
 //
 // Yield to incoming messages
 //
-bool wxYield()
+bool wxApp::Yield(bool onlyIfNeeded)
 {
+    static bool s_inYield = FALSE;
+
+    if ( s_inYield )
+    {
+        if ( !onlyIfNeeded )
+        {
+            wxFAIL_MSG( _T("wxYield() called recursively") );
+        }
+
+        return FALSE;
+    }
+
     HAB                             vHab = 0;
     QMSG                            vMsg;
 
@@ -1133,7 +1143,7 @@ bool wxYield()
     //
     wxLog::Suspend();
 
-    gs_inYield = TRUE;
+    s_inYield = TRUE;
 
     //
     // We want to go back to the main message loop
@@ -1157,19 +1167,10 @@ bool wxYield()
     // Let the logs be flashed again
     //
     wxLog::Resume();
-    gs_inYield = FALSE;
+    s_inYield = FALSE;
     return TRUE;
 } // end of wxYield
 
-// Yield to incoming messages; but fail silently if recursion is detected.
-bool wxYieldIfNeeded()
-{
-    if (gs_inYield)
-        return FALSE;
-
-    return wxYield();
-}
-
 wxIcon wxApp::GetStdIcon(
   int                               nWhich
 ) const