diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ephy-tab.c | 7 | ||||
-rw-r--r-- | src/ephy-window.c | 62 |
2 files changed, 38 insertions, 31 deletions
diff --git a/src/ephy-tab.c b/src/ephy-tab.c index 65c2af8c4..e40e51207 100644 --- a/src/ephy-tab.c +++ b/src/ephy-tab.c @@ -1015,6 +1015,9 @@ ephy_tab_dom_mouse_click_cb (EphyEmbed *embed, context = ephy_embed_event_get_context (event); modifier = ephy_embed_event_get_modifier (event); + LOG ("ephy_tab_dom_mouse_click_cb: type %d, context %x, modifier %x", + type, context, modifier) + with_control = (modifier & GDK_CONTROL_MASK) != 0; with_shift = (modifier & GDK_SHIFT_MASK) != 0; is_left_click = (type == EPHY_EMBED_EVENT_MOUSE_BUTTON1); @@ -1045,8 +1048,8 @@ ephy_tab_dom_mouse_click_cb (EphyEmbed *embed, { save_property_url (embed, event, "link", CONF_STATE_DOWNLOAD_DIR); } - /* shift+click saves the non-link image, except when it's the submit - * button for a form + /* shift+click saves the non-link image + * Note: pressing enter to submit a form synthesizes a mouse click event */ else if (is_image && is_left_click && with_shift && !is_input) { diff --git a/src/ephy-window.c b/src/ephy-window.c index 1a9289150..333205d62 100644 --- a/src/ephy-window.c +++ b/src/ephy-window.c @@ -733,7 +733,7 @@ init_menu_updaters (EphyWindow *window) } static void -setup_window (EphyWindow *window) +setup_ui_manager (EphyWindow *window) { GtkActionGroup *action_group; GtkAction *action; @@ -805,23 +805,6 @@ setup_window (EphyWindow *window) g_warning ("Could not merge epiphany-ui.xml: %s", err->message); g_clear_error (&err); } - - gtk_ui_manager_ensure_update (GTK_UI_MANAGER (window->ui_merge)); - - init_menu_updaters (window); - - window->priv->toolbar = toolbar_new (window); - gtk_widget_show (GTK_WIDGET (window->priv->toolbar)); - gtk_box_pack_end (GTK_BOX (window->priv->menu_dock), - GTK_WIDGET (window->priv->toolbar), - FALSE, FALSE, 0); - g_signal_connect (window, - "selection-received", - G_CALLBACK (ephy_window_selection_received_cb), - window); - g_signal_connect (window, "window-state-event", - G_CALLBACK (ephy_window_state_event_cb), - window); } static void @@ -1460,8 +1443,6 @@ setup_notebook (EphyWindow *window) g_signal_connect (G_OBJECT (notebook), "tabs_reordered", G_CALLBACK (tabs_reordered_cb), window); - gtk_widget_show (GTK_WIDGET (notebook)); - return notebook; } @@ -1610,31 +1591,53 @@ ephy_window_init (EphyWindow *window) ensure_default_icon (); - /* Setup the window and connect verbs */ - setup_window (window); + g_object_ref (ephy_shell); + + /* Setup the UI manager and connect verbs */ + setup_ui_manager (window); + + window->priv->toolbar = toolbar_new (window); + gtk_box_pack_end (GTK_BOX (window->priv->menu_dock), + GTK_WIDGET (window->priv->toolbar), + FALSE, FALSE, 0); + - /* Setup window contents */ window->priv->notebook = setup_notebook (window); gtk_box_pack_start (GTK_BOX (window->priv->main_vbox), GTK_WIDGET (window->priv->notebook), TRUE, TRUE, 0); window->priv->statusbar = statusbar_new (); - gtk_widget_show (window->priv->statusbar); gtk_box_pack_start (GTK_BOX (window->priv->main_vbox), GTK_WIDGET (window->priv->statusbar), FALSE, TRUE, 0); window->priv->tab_message_cid = gtk_statusbar_get_context_id (GTK_STATUSBAR (window->priv->statusbar), "tab_message"); - g_object_ref (ephy_shell); - /* Initialize the menus */ window->priv->tabs_menu = ephy_tabs_menu_new (window); window->priv->fav_menu = ephy_favorites_menu_new (window); window->priv->enc_menu = ephy_encoding_menu_new (window); window->priv->bmk_menu = ephy_bookmarks_menu_new (window); + /* Once the window is sufficiently created let the extensions attach to it */ + manager = EPHY_EXTENSION (ephy_shell_get_extensions_manager (ephy_shell)); + ephy_extension_attach_window (manager, window); + + /* show widgets */ + gtk_widget_show (GTK_WIDGET (window->priv->toolbar)); + gtk_widget_show (GTK_WIDGET (window->priv->notebook)); + gtk_widget_show (window->priv->statusbar); + + g_signal_connect (window, + "selection-received", + G_CALLBACK (ephy_window_selection_received_cb), + window); + g_signal_connect (window, "window-state-event", + G_CALLBACK (ephy_window_state_event_cb), + window); + + /* lockdown pref notifiers */ window->priv->disable_js_chrome_notifier_id = eel_gconf_notification_add (CONF_LOCKDOWN_DISABLE_JAVASCRIPT_CHROME, (GConfClientNotifyFunc)chrome_notifier, window); @@ -1655,9 +1658,10 @@ ephy_window_init (EphyWindow *window) (CONF_LOCKDOWN_HIDE_MENUBAR, (GConfClientNotifyFunc)chrome_notifier, window); - /* Once the window is fully created let the extensions attach to it */ - manager = EPHY_EXTENSION (ephy_shell_get_extensions_manager (ephy_shell)); - ephy_extension_attach_window (manager, window); + /* ensure the UI is updated */ + gtk_ui_manager_ensure_update (GTK_UI_MANAGER (window->ui_merge)); + + init_menu_updaters (window); } static void |