diff options
author | Xan Lopez <xlopez@igalia.com> | 2011-06-28 03:48:44 +0800 |
---|---|---|
committer | Xan Lopez <xlopez@igalia.com> | 2011-06-28 03:48:44 +0800 |
commit | 7b740a66f80864abf24c2e8eddcfd624ef434ae7 (patch) | |
tree | 185635b7d28ad54191d3f4527f6cf30c58db4db8 /src/ephy-window.c | |
parent | 972de8b227165ed15f65c6401698501bdcd34565 (diff) | |
download | gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.tar gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.tar.gz gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.tar.bz2 gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.tar.lz gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.tar.xz gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.tar.zst gsoc2013-epiphany-7b740a66f80864abf24c2e8eddcfd624ef434ae7.zip |
Respect gtk-keynav-wrap-around in the global change-page handler
We have a global-handler for Ctrl+Page{Up,Down} that is used in some
situations (basically, when the notebook is not focused). It does not
respect the wrap-around GtkSetting though, so the final experience can
be inconsistent.
Diffstat (limited to 'src/ephy-window.c')
-rw-r--r-- | src/ephy-window.c | 39 |
1 files changed, 25 insertions, 14 deletions
diff --git a/src/ephy-window.c b/src/ephy-window.c index 28031e545..9f459b74e 100644 --- a/src/ephy-window.c +++ b/src/ephy-window.c @@ -2839,24 +2839,35 @@ update_tabs_menu_sensitivity (EphyWindow *window) GtkActionGroup *action_group; GtkAction *action; GtkNotebook *notebook; - int page, n_pages; - gboolean not_first, not_last; + gboolean wrap_around; + int n_pages; notebook = GTK_NOTEBOOK (priv->notebook); - page = gtk_notebook_get_current_page (notebook); + action_group = priv->action_group; n_pages = gtk_notebook_get_n_pages (notebook); - not_first = page > 0; - not_last = page + 1 < n_pages; - action_group = priv->action_group; - action = gtk_action_group_get_action (action_group, "TabsPrevious"); - gtk_action_set_sensitive (action, not_first); - action = gtk_action_group_get_action (action_group, "TabsNext"); - gtk_action_set_sensitive (action, not_last); - action = gtk_action_group_get_action (action_group, "TabsMoveLeft"); - gtk_action_set_sensitive (action, not_first); - action = gtk_action_group_get_action (action_group, "TabsMoveRight"); - gtk_action_set_sensitive (action, not_last); + g_object_get (gtk_widget_get_settings (GTK_WIDGET (notebook)), + "gtk-keynav-wrap-around", &wrap_around, + NULL); + + if (!wrap_around) + { + int page; + gboolean not_first, not_last; + + page = gtk_notebook_get_current_page (notebook); + not_first = page > 0; + not_last = page + 1 < n_pages; + + action = gtk_action_group_get_action (action_group, "TabsPrevious"); + gtk_action_set_sensitive (action, not_first); + action = gtk_action_group_get_action (action_group, "TabsNext"); + gtk_action_set_sensitive (action, not_last); + action = gtk_action_group_get_action (action_group, "TabsMoveLeft"); + gtk_action_set_sensitive (action, not_first); + action = gtk_action_group_get_action (action_group, "TabsMoveRight"); + gtk_action_set_sensitive (action, not_last); + } action = gtk_action_group_get_action (action_group, "TabsDetach"); ephy_action_change_sensitivity_flags (action, SENS_FLAG_CHROME, n_pages <= 1); |