]> git.saurik.com Git - wxWidgets.git/commitdiff
Correction to my new menu code: handle submenus on menubar menus
authorRobin Dunn <robin@alldunn.com>
Thu, 3 Apr 2003 21:01:52 +0000 (21:01 +0000)
committerRobin Dunn <robin@alldunn.com>
Thu, 3 Apr 2003 21:01:52 +0000 (21:01 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@19970 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

src/gtk/menu.cpp
src/gtk1/menu.cpp

index dc12c62e984ac2fc13107a131765043ad70174fe..88eb8cf728ff54b81fdd36b7fc54a5c16fe82885 100644 (file)
@@ -701,11 +701,23 @@ static void gtk_menu_clicked_callback( GtkWidget *widget, wxMenu *menu )
     if (!menu->IsEnabled(id))
         return;
 
     if (!menu->IsEnabled(id))
         return;
 
-    if ( menu->IsAttached() ) // is this menu on a menubar?
+    // Is this menu on a menubar?  (possibly nested)
+    wxFrame* frame = NULL;
+    wxMenu*  pm = menu;
+    while ( pm && !frame )
+    {
+        if ( pm->IsAttached() )
+            frame = pm->GetMenuBar()->GetFrame();
+        else
+            pm = pm->GetParent();
+    }
+
+    // If it is then let the frame send the event
+    if (frame)
     {
     {
-        wxFrame* frame = menu->GetMenuBar()->GetFrame();
         frame->ProcessCommand(id);
     }
         frame->ProcessCommand(id);
     }
+    // otherwise let the menu have it
     else
     {
         wxMenuItem* item = menu->FindChildItem( id );
     else
     {
         wxMenuItem* item = menu->FindChildItem( id );
index dc12c62e984ac2fc13107a131765043ad70174fe..88eb8cf728ff54b81fdd36b7fc54a5c16fe82885 100644 (file)
@@ -701,11 +701,23 @@ static void gtk_menu_clicked_callback( GtkWidget *widget, wxMenu *menu )
     if (!menu->IsEnabled(id))
         return;
 
     if (!menu->IsEnabled(id))
         return;
 
-    if ( menu->IsAttached() ) // is this menu on a menubar?
+    // Is this menu on a menubar?  (possibly nested)
+    wxFrame* frame = NULL;
+    wxMenu*  pm = menu;
+    while ( pm && !frame )
+    {
+        if ( pm->IsAttached() )
+            frame = pm->GetMenuBar()->GetFrame();
+        else
+            pm = pm->GetParent();
+    }
+
+    // If it is then let the frame send the event
+    if (frame)
     {
     {
-        wxFrame* frame = menu->GetMenuBar()->GetFrame();
         frame->ProcessCommand(id);
     }
         frame->ProcessCommand(id);
     }
+    // otherwise let the menu have it
     else
     {
         wxMenuItem* item = menu->FindChildItem( id );
     else
     {
         wxMenuItem* item = menu->FindChildItem( id );