aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@gnome.org>2004-04-18 18:29:03 +0800
committerChristian Persch <chpe@src.gnome.org>2004-04-18 18:29:03 +0800
commit187c9cdee99497964d4ff05ca609e2d40240920c (patch)
tree0d8aa86ebc97fb5c31cf1aea84bc911508b513a7
parent4718a00482f6b2c952dd1cc6cd5abf20eda3365b (diff)
downloadgsoc2013-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--ChangeLog11
-rw-r--r--embed/ephy-embed.c1
-rw-r--r--embed/ephy-embed.h14
-rw-r--r--embed/mozilla/mozilla-embed.cpp1
-rw-r--r--src/ephy-window.c43
5 files changed, 42 insertions, 28 deletions
diff --git a/ChangeLog b/ChangeLog
index 57e14926d..75dec50c8 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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));