aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog13
-rw-r--r--embed/mozilla/AutoEventQueue.cpp106
-rw-r--r--embed/mozilla/AutoEventQueue.h75
-rw-r--r--embed/mozilla/GtkNSSSecurityWarningDialogs.cpp7
-rw-r--r--embed/mozilla/Makefile.am2
5 files changed, 203 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index f2c861ad2..bd9bb805f 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,16 @@
+2005-09-26 Christian Persch <chpe@cvs.gnome.org>
+
+ * embed/mozilla/Makefile.am:
+ * embed/mozilla/AutoEventQueue.cpp:
+ * embed/mozilla/AutoEventQueue.h:
+ * embed/mozilla/GtkNSSSecurityWarningDialogs.cpp: (DoDialog):
+
+ Push a new event queue while showing the dialogue
+ with gtk_dialog_run. This fixes the problem (caused by the
+ braindead API of showing this dialogue synchronously) that
+ networking is blocked in all other windows while the dialogue
+ is shown.
+
2005-09-25 Jean-François Rameau <jframeau@cvs.gnome.org>
* data/epiphany-lockdown.schemas.in:
diff --git a/embed/mozilla/AutoEventQueue.cpp b/embed/mozilla/AutoEventQueue.cpp
new file mode 100644
index 000000000..46ec2cb93
--- /dev/null
+++ b/embed/mozilla/AutoEventQueue.cpp
@@ -0,0 +1,106 @@
+/*
+ * Copied from nsWindowWatcher.cpp.
+ *
+ * ***** BEGIN LICENSE BLOCK *****
+ * Version: MPL 1.1/GPL 2.0/LGPL 2.1
+ *
+ * The contents of this file are subject to the Mozilla Public License Version
+ * 1.1 (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ * http://www.mozilla.org/MPL/
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is mozilla.org code.
+ *
+ * The Initial Developer of the Original Code is
+ * Netscape Communications Corporation.
+ * Portions created by the Initial Developer are Copyright (C) 2001
+ * the Initial Developer. All Rights Reserved.
+ *
+ * Contributor(s):
+ * Harshal Pradhan <keeda@hotpop.com>
+ *
+ * Alternatively, the contents of this file may be used under the terms of
+ * either the GNU General Public License Version 2 or later (the "GPL"), or
+ * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
+ * in which case the provisions of the GPL or the LGPL are applicable instead
+ * of those above. If you wish to allow use of your version of this file only
+ * under the terms of either the GPL or the LGPL, and not to allow others to
+ * use your version of this file under the terms of the MPL, indicate your
+ * decision by deleting the provisions above and replace them with the notice
+ * and other provisions required by the GPL or the LGPL. If you do not delete
+ * the provisions above, a recipient may use your version of this file under
+ * the terms of any one of the MPL, the GPL or the LGPL.
+ *
+ * ***** END LICENSE BLOCK *****
+ *
+ * $Id$
+ */
+
+#include "mozilla-config.h"
+#include "config.h"
+
+#include "AutoEventQueue.h"
+
+#ifdef HAVE_LAME_APPSHELL
+/* for NS_APPSHELL_CID */
+#include <nsWidgetsCID.h>
+#endif
+#include <nsIServiceManager.h>
+#include <nsIServiceManagerUtils.h>
+
+#ifdef HAVE_LAME_APPSHELL
+static NS_DEFINE_CID(kAppShellCID, NS_APPSHELL_CID);
+#endif
+
+AutoEventQueue::AutoEventQueue() : mQueue(nsnull)
+{
+}
+
+AutoEventQueue::~AutoEventQueue()
+{
+#ifdef HAVE_LAME_APPSHELL
+ if (mAppShell) {
+ if (mQueue)
+ mAppShell->ListenToEventQueue(mQueue, PR_FALSE);
+ mAppShell->Spindown();
+ mAppShell = nsnull;
+ }
+#endif
+
+ if(mQueue)
+ mService->PopThreadEventQueue(mQueue);
+}
+
+nsresult AutoEventQueue::Init()
+{
+ if (mQueue)
+ return NS_ERROR_ALREADY_INITIALIZED;
+
+ mService = do_GetService(NS_EVENTQUEUESERVICE_CONTRACTID);
+ if (!mService)
+ return NS_ERROR_FAILURE;
+
+ /* push a new queue onto it */
+ mService->PushThreadEventQueue(getter_AddRefs(mQueue));
+ if (!mQueue)
+ return NS_ERROR_FAILURE;
+
+#ifdef HAVE_LAME_APPSHELL
+ mAppShell = do_CreateInstance(kAppShellCID);
+ if (!mAppShell)
+ return NS_ERROR_FAILURE;
+
+ mAppShell->Create(0, nsnull);
+ mAppShell->Spinup();
+
+ /* listen to the new queue */
+ mAppShell->ListenToEventQueue(mQueue, PR_TRUE);
+#endif
+
+ return NS_OK;
+}
diff --git a/embed/mozilla/AutoEventQueue.h b/embed/mozilla/AutoEventQueue.h
new file mode 100644
index 000000000..4b3ae3320
--- /dev/null
+++ b/embed/mozilla/AutoEventQueue.h
@@ -0,0 +1,75 @@
+/*
+ * Copied from nsWindowWatcher.cpp.
+ *
+ * ***** BEGIN LICENSE BLOCK *****
+ * Version: MPL 1.1/GPL 2.0/LGPL 2.1
+ *
+ * The contents of this file are subject to the Mozilla Public License Version
+ * 1.1 (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ * http://www.mozilla.org/MPL/
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is mozilla.org code.
+ *
+ * The Initial Developer of the Original Code is
+ * Netscape Communications Corporation.
+ * Portions created by the Initial Developer are Copyright (C) 2001
+ * the Initial Developer. All Rights Reserved.
+ *
+ * Contributor(s):
+ * Harshal Pradhan <keeda@hotpop.com>
+ *
+ * Alternatively, the contents of this file may be used under the terms of
+ * either the GNU General Public License Version 2 or later (the "GPL"), or
+ * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
+ * in which case the provisions of the GPL or the LGPL are applicable instead
+ * of those above. If you wish to allow use of your version of this file only
+ * under the terms of either the GPL or the LGPL, and not to allow others to
+ * use your version of this file under the terms of the MPL, indicate your
+ * decision by deleting the provisions above and replace them with the notice
+ * and other provisions required by the GPL or the LGPL. If you do not delete
+ * the provisions above, a recipient may use your version of this file under
+ * the terms of any one of the MPL, the GPL or the LGPL.
+ *
+ * ***** END LICENSE BLOCK *****
+ *
+ * $Id$
+ */
+
+#ifndef AUTO_EVENT_QUEUE
+#define AUTO_EVENT_QUEUE
+
+#include <nsCOMPtr.h>
+#include <nsIEventQueue.h>
+#include <nsIEventQueueService.h>
+
+#ifdef XP_UNIX
+/* please see bugzilla.mozilla.org/show_bug.cgi?id=78421 for the eventual "right" fix for this */
+#define HAVE_LAME_APPSHELL
+#endif
+
+#ifdef HAVE_LAME_APPSHELL
+#include <nsIAppShell.h>
+#endif
+
+class AutoEventQueue {
+public:
+ AutoEventQueue();
+ ~AutoEventQueue();
+
+ nsresult Init();
+
+protected:
+ nsCOMPtr<nsIEventQueueService> mService;
+ nsCOMPtr<nsIEventQueue> mQueue;
+#ifdef HAVE_LAME_APPSHELL
+ nsCOMPtr<nsIAppShell> mAppShell;
+#endif
+};
+
+#endif
diff --git a/embed/mozilla/GtkNSSSecurityWarningDialogs.cpp b/embed/mozilla/GtkNSSSecurityWarningDialogs.cpp
index faec73741..1caa3e415 100644
--- a/embed/mozilla/GtkNSSSecurityWarningDialogs.cpp
+++ b/embed/mozilla/GtkNSSSecurityWarningDialogs.cpp
@@ -47,6 +47,7 @@
#include "GtkNSSSecurityWarningDialogs.h"
#include "EphyUtils.h"
+#include "AutoEventQueue.h"
#include <nsCOMPtr.h>
#include <nsIPrefBranch.h>
@@ -200,6 +201,12 @@ GtkNSSSecurityWarningDialogs::DoDialog (nsIInterfaceRequestor *aContext,
{
*_retval = PR_FALSE;
+ /* Work around this broken API by pushing a new event queue. Otherwise
+ * networking will block while the dialogue is shown!
+ */
+ AutoEventQueue queue;
+ if (NS_FAILED (queue.Init ())) return;
+
nsresult rv;
PRBool show = PR_TRUE;
nsCOMPtr<nsIPrefBranch> prefBranch
diff --git a/embed/mozilla/Makefile.am b/embed/mozilla/Makefile.am
index ae1585ca2..def68f77b 100644
--- a/embed/mozilla/Makefile.am
+++ b/embed/mozilla/Makefile.am
@@ -1,6 +1,8 @@
noinst_LTLIBRARIES = libephymozillaembed.la
libephymozillaembed_la_SOURCES = \
+ AutoEventQueue.cpp \
+ AutoEventQueue.h \
ContentHandler.cpp \
ContentHandler.h \
EphyContentPolicy.cpp \