aboutsummaryrefslogtreecommitdiffstats
path: root/embed/mozilla/EphyBrowser.cpp
diff options
context:
space:
mode:
authorChristian Persch <chpe@cvs.gnome.org>2004-06-15 06:33:15 +0800
committerChristian Persch <chpe@src.gnome.org>2004-06-15 06:33:15 +0800
commit696f5d076f397929d9527f7e6f3c127ede2c00f9 (patch)
tree1101c91e42a44f0fe6ad681df057e3f244fc1698 /embed/mozilla/EphyBrowser.cpp
parent7df4f3cd1d2f6fc0543c81c041d250941abc81f7 (diff)
downloadgsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.tar
gsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.tar.gz
gsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.tar.bz2
gsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.tar.lz
gsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.tar.xz
gsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.tar.zst
gsoc2013-epiphany-696f5d076f397929d9527f7e6f3c127ede2c00f9.zip
Work around mozilla bug #246392 which goes back to the original urls when
2004-06-15 Christian Persch <chpe@cvs.gnome.org> * embed/mozilla/EphyBrowser.cpp: * embed/mozilla/EphyBrowser.h: * embed/mozilla/mozilla-embed.cpp: Work around mozilla bug #246392 which goes back to the original urls when reloading a frameset. Fixes bug #115800.
Diffstat (limited to 'embed/mozilla/EphyBrowser.cpp')
-rw-r--r--embed/mozilla/EphyBrowser.cpp38
1 files changed, 38 insertions, 0 deletions
diff --git a/embed/mozilla/EphyBrowser.cpp b/embed/mozilla/EphyBrowser.cpp
index 061eba80c..9101ea31f 100644
--- a/embed/mozilla/EphyBrowser.cpp
+++ b/embed/mozilla/EphyBrowser.cpp
@@ -415,6 +415,44 @@ nsresult EphyBrowser::GoToHistoryIndex (PRInt16 index)
return ContentNav->GotoIndex (index);
}
+/* Workaround for broken reload with frames, see mozilla bug
+ * http://bugzilla.mozilla.org/show_bug.cgi?id=246392
+ */
+nsresult EphyBrowser::Reload (PRUint32 flags)
+{
+ NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
+
+ nsCOMPtr<nsISHistory> sessionHistory;
+ GetSHistory (getter_AddRefs (sessionHistory));
+
+ nsCOMPtr<nsIWebNavigation> webNavigation;
+ webNavigation = do_QueryInterface (sessionHistory);
+
+ if (!webNavigation)
+ {
+ webNavigation = do_QueryInterface (mWebBrowser);
+ }
+ NS_ENSURE_TRUE (webNavigation, NS_ERROR_FAILURE);
+
+ PRUint32 reloadFlags;
+ switch (flags)
+ {
+ case RELOAD_FORCE:
+ reloadFlags = nsIWebNavigation::LOAD_FLAGS_BYPASS_CACHE |
+ nsIWebNavigation::LOAD_FLAGS_BYPASS_PROXY;
+ break;
+ case RELOAD_ENCODING_CHANGE:
+ reloadFlags = nsIWebNavigation::LOAD_FLAGS_CHARSET_CHANGE;
+ break;
+ case RELOAD_NORMAL:
+ default:
+ reloadFlags = 0;
+ break;
+ }
+
+ return webNavigation->Reload (reloadFlags);
+}
+
nsresult EphyBrowser::SetZoom (float aZoom, PRBool reflow)
{
if (!mWebBrowser) return NS_ERROR_FAILURE;