From: Nickolay V. Shmyrev Date: Tue, 30 Jan 2007 18:55:12 +0000 (+0000) Subject: Correctly show menu and fix crash when navigaton action is out of toolbar X-Git-Tag: EVINCE_0_7_2~43 X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=commitdiff_plain;h=e98242e3e677e78840e8a417801c2831602831ce;p=evince.git Correctly show menu and fix crash when navigaton action is out of toolbar 2007-01-30 Nickolay V. Shmyrev * shell/ev-navigation-action.c: (connect_proxy), (create_menu_item), (ev_navigation_action_class_init): Correctly show menu and fix crash when navigaton action is out of toolbar visible area. svn path=/trunk/; revision=2278 --- diff --git a/ChangeLog b/ChangeLog index 3a68a035..770568bc 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2007-01-30 Nickolay V. Shmyrev + + * shell/ev-navigation-action.c: (connect_proxy), + (create_menu_item), (ev_navigation_action_class_init): + + Correctly show menu and fix crash when navigaton + action is out of toolbar visible area. + 2007-01-30 Nickolay V. Shmyrev * data/Makefile.am: diff --git a/shell/ev-navigation-action.c b/shell/ev-navigation-action.c index c87940a6..c4f61917 100644 --- a/shell/ev-navigation-action.c +++ b/shell/ev-navigation-action.c @@ -166,12 +166,14 @@ connect_proxy (GtkAction *action, GtkWidget *proxy) { GtkWidget *menu; - /* set dummy menu so the arrow gets sensitive */ - menu = gtk_menu_new (); - ev_navigation_action_widget_set_menu (EV_NAVIGATION_ACTION_WIDGET (proxy), menu); + if (EV_IS_NAVIGATION_ACTION (proxy)) { + /* set dummy menu so the arrow gets sensitive */ + menu = gtk_menu_new (); + ev_navigation_action_widget_set_menu (EV_NAVIGATION_ACTION_WIDGET (proxy), menu); - g_signal_connect (proxy, "show-menu", - G_CALLBACK (menu_activated_cb), action); + g_signal_connect (proxy, "show-menu", + G_CALLBACK (menu_activated_cb), action); + } GTK_ACTION_CLASS (ev_navigation_action_parent_class)->connect_proxy (action, proxy); } @@ -187,6 +189,23 @@ create_tool_item (GtkAction *action) return GTK_WIDGET (proxy); } +static GtkWidget * +create_menu_item (GtkAction *action) +{ + GtkWidget *menu; + GtkWidget *menu_item; + + menu = build_menu (EV_NAVIGATION_ACTION (action)); + + menu_item = GTK_ACTION_CLASS (ev_navigation_action_parent_class)->create_menu_item (action); + + gtk_menu_item_set_submenu (GTK_MENU_ITEM (menu_item), menu); + + gtk_widget_show (menu_item); + + return menu_item; +} + static void ev_navigation_action_init (EvNavigationAction *action) { @@ -217,6 +236,7 @@ ev_navigation_action_class_init (EvNavigationActionClass *class) action_class->toolbar_item_type = GTK_TYPE_TOOL_ITEM; action_class->create_tool_item = create_tool_item; action_class->connect_proxy = connect_proxy; + action_class->create_menu_item = create_menu_item; widget_signals[WIDGET_ACTIVATE_LINK] = g_signal_new ("activate_link", G_OBJECT_CLASS_TYPE (object_class),