diff options
author | Marco Pesenti Gritti <marco@gnome.org> | 2004-04-18 18:29:03 +0800 |
---|---|---|
committer | Christian Persch <chpe@src.gnome.org> | 2004-04-18 18:29:03 +0800 |
commit | 187c9cdee99497964d4ff05ca609e2d40240920c (patch) | |
tree | 0d8aa86ebc97fb5c31cf1aea84bc911508b513a7 | |
parent | 4718a00482f6b2c952dd1cc6cd5abf20eda3365b (diff) | |
download | gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.tar gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.tar.gz gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.tar.bz2 gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.tar.lz gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.tar.xz gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.tar.zst gsoc2013-epiphany-187c9cdee99497964d4ff05ca609e2d40240920c.zip |
Fix chrome for new windows opened from _blank target. Fixes bug #139512.
2004-04-18 Marco Pesenti Gritti <marco@gnome.org>
* embed/ephy-embed.c: (ephy_embed_chrome_get_type):
* embed/ephy-embed.h:
* embed/mozilla/mozilla-embed.cpp:
* src/ephy-window.c: (ephy_window_set_chrome),
(ephy_window_set_property), (ephy_window_class_init):
Fix chrome for new windows opened from _blank target.
Fixes bug #139512.
-rw-r--r-- | ChangeLog | 11 | ||||
-rw-r--r-- | embed/ephy-embed.c | 1 | ||||
-rw-r--r-- | embed/ephy-embed.h | 14 | ||||
-rw-r--r-- | embed/mozilla/mozilla-embed.cpp | 1 | ||||
-rw-r--r-- | src/ephy-window.c | 43 |
5 files changed, 42 insertions, 28 deletions
@@ -1,3 +1,14 @@ +2004-04-18 Marco Pesenti Gritti <marco@gnome.org> + + * embed/ephy-embed.c: (ephy_embed_chrome_get_type): + * embed/ephy-embed.h: + * embed/mozilla/mozilla-embed.cpp: + * src/ephy-window.c: (ephy_window_set_chrome), + (ephy_window_set_property), (ephy_window_class_init): + + Fix chrome for new windows opened from _blank target. + Fixes bug #139512. + 2004-04-18 Christian Persch <chpe@cvs.gnome.org> * embed/mozilla/EphyContentPolicy.h: diff --git a/embed/ephy-embed.c b/embed/ephy-embed.c index 97dfa058a..c78ca6b1f 100644 --- a/embed/ephy-embed.c +++ b/embed/ephy-embed.c @@ -39,7 +39,6 @@ ephy_embed_chrome_get_type (void) { static const GFlagsValue values[] = { - { EPHY_EMBED_CHROME_DEFAULT, "EPHY_EMBED_CHROME_DEFAULT", "default" }, { EPHY_EMBED_CHROME_MENUBAR, "EPHY_EMBED_CHROME_MENUBAR", "menubar" }, { EPHY_EMBED_CHROME_TOOLBAR, "EPHY_EMBED_CHROME_TOOLBAR", "toolbar" }, { EPHY_EMBED_CHROME_STATUSBAR, "EPHY_EMBED_CHROME_STATUSBAR", "statusbar" }, diff --git a/embed/ephy-embed.h b/embed/ephy-embed.h index 4ca0e1e15..0099385dd 100644 --- a/embed/ephy-embed.h +++ b/embed/ephy-embed.h @@ -59,13 +59,17 @@ typedef enum typedef enum { - EPHY_EMBED_CHROME_DEFAULT = 1 << 0, - EPHY_EMBED_CHROME_MENUBAR = 1 << 1, - EPHY_EMBED_CHROME_TOOLBAR = 1 << 2, - EPHY_EMBED_CHROME_STATUSBAR = 1 << 3, - EPHY_EMBED_CHROME_BOOKMARKSBAR = 1 << 4 + EPHY_EMBED_CHROME_MENUBAR = 1 << 0, + EPHY_EMBED_CHROME_TOOLBAR = 1 << 1, + EPHY_EMBED_CHROME_STATUSBAR = 1 << 2, + EPHY_EMBED_CHROME_BOOKMARKSBAR = 1 << 3 } EphyEmbedChrome; +#define EPHY_EMBED_CHROME_ALL (EPHY_EMBED_CHROME_MENUBAR | \ + EPHY_EMBED_CHROME_TOOLBAR | \ + EPHY_EMBED_CHROME_STATUSBAR | \ + EPHY_EMBED_CHROME_BOOKMARKSBAR) + typedef enum { EMBED_RELOAD_NORMAL = 1 << 0, diff --git a/embed/mozilla/mozilla-embed.cpp b/embed/mozilla/mozilla-embed.cpp index 55cea060e..b8f00932b 100644 --- a/embed/mozilla/mozilla-embed.cpp +++ b/embed/mozilla/mozilla-embed.cpp @@ -997,7 +997,6 @@ mozilla_embed_new_window_cb (GtkMozEmbed *embed, } conversion_map [] = { - { GTK_MOZ_EMBED_FLAG_DEFAULTCHROME, EPHY_EMBED_CHROME_DEFAULT }, { GTK_MOZ_EMBED_FLAG_MENUBARON, EPHY_EMBED_CHROME_MENUBAR }, { GTK_MOZ_EMBED_FLAG_TOOLBARON, EPHY_EMBED_CHROME_TOOLBAR }, { GTK_MOZ_EMBED_FLAG_STATUSBARON, EPHY_EMBED_CHROME_STATUSBAR }, diff --git a/src/ephy-window.c b/src/ephy-window.c index ca9c0b9e7..cfa6bad59 100644 --- a/src/ephy-window.c +++ b/src/ephy-window.c @@ -1727,32 +1727,40 @@ setup_notebook (EphyWindow *window) return notebook; } -static EphyEmbedChrome -get_default_chrome (void) +static void +ephy_window_set_chrome (EphyWindow *window, EphyEmbedChrome mask) { - EphyEmbedChrome chrome_mask = 0; + EphyEmbedChrome chrome_mask = mask; + + if (mask == EPHY_EMBED_CHROME_ALL) + { + window->priv->should_save_chrome = TRUE; + } - if (eel_gconf_get_boolean (CONF_WINDOWS_SHOW_TOOLBARS)) + if (!eel_gconf_get_boolean (CONF_WINDOWS_SHOW_TOOLBARS)) { - chrome_mask |= EPHY_EMBED_CHROME_TOOLBAR; + chrome_mask &= ~EPHY_EMBED_CHROME_TOOLBAR; } - if (eel_gconf_get_boolean (CONF_WINDOWS_SHOW_STATUSBAR)) + if (!eel_gconf_get_boolean (CONF_WINDOWS_SHOW_STATUSBAR)) { - chrome_mask |= EPHY_EMBED_CHROME_STATUSBAR; + chrome_mask &= ~EPHY_EMBED_CHROME_STATUSBAR; } - if (!eel_gconf_get_boolean (CONF_LOCKDOWN_HIDE_MENUBAR)) + if (!eel_gconf_get_boolean (CONF_WINDOWS_SHOW_BOOKMARKS_BAR)) { - chrome_mask |= EPHY_EMBED_CHROME_MENUBAR; + chrome_mask &= ~EPHY_EMBED_CHROME_BOOKMARKSBAR; } - if (eel_gconf_get_boolean (CONF_WINDOWS_SHOW_BOOKMARKS_BAR)) + if (eel_gconf_get_boolean (CONF_LOCKDOWN_HIDE_MENUBAR)) { - chrome_mask |= EPHY_EMBED_CHROME_BOOKMARKSBAR; + chrome_mask &= ~EPHY_EMBED_CHROME_MENUBAR; } - return chrome_mask; + window->priv->chrome = chrome_mask; + + sync_chromes_visibility (window); + update_chromes_actions (window); } static void @@ -1769,14 +1777,7 @@ ephy_window_set_property (GObject *object, ephy_window_set_active_tab (window, g_value_get_object (value)); break; case PROP_CHROME: - window->priv->chrome = g_value_get_flags (value); - if (window->priv->chrome == EPHY_EMBED_CHROME_DEFAULT) - { - window->priv->chrome = get_default_chrome (); - window->priv->should_save_chrome = TRUE; - } - sync_chromes_visibility (window); - update_chromes_actions (window); + ephy_window_set_chrome (window, g_value_get_flags (value)); break; } } @@ -1828,7 +1829,7 @@ ephy_window_class_init (EphyWindowClass *klass) "chrome", "Window chrome", EPHY_TYPE_EMBED_CHROME_MASK, - EPHY_EMBED_CHROME_DEFAULT, + EPHY_EMBED_CHROME_ALL, G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE)); |