[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r19072: {torbutton} Bug 866: Fix Zotero conflict. (torbutton/trunk/src/chrome/content)
Author: mikeperry
Date: 2009-03-18 00:14:30 -0400 (Wed, 18 Mar 2009)
New Revision: 19072
Modified:
torbutton/trunk/src/chrome/content/torbutton.js
Log:
Bug 866: Fix Zotero conflict.
Modified: torbutton/trunk/src/chrome/content/torbutton.js
===================================================================
--- torbutton/trunk/src/chrome/content/torbutton.js 2009-03-18 02:39:21 UTC (rev 19071)
+++ torbutton/trunk/src/chrome/content/torbutton.js 2009-03-18 04:14:30 UTC (rev 19072)
@@ -2209,7 +2209,7 @@
if (topic == "http-on-examine-response") {
torbutton_eclog(3, 'Definitaly Examine response: '+subject.name);
- torbutton_check_progress(null, subject);
+ torbutton_check_progress(null, subject, 0);
} else if (topic == "http-on-modify-request") {
torbutton_eclog(3, 'Modify request: '+subject.name);
}
@@ -2799,13 +2799,27 @@
// of its being called so early. Need to find a quick way to check if
// aProgress and aRequest are actually fully initialized
// (without throwing exceptions)
-function torbutton_check_progress(aProgress, aRequest) {
+function torbutton_check_progress(aProgress, aRequest, aFlags) {
if (!m_tb_wasinited) {
torbutton_init();
}
var DOMWindow = null;
+ // Bug #866: Zotero conflict with about:blank windows
+ // handle docshell JS switching and other early duties
+ var WP_STATE_START = Ci.nsIWebProgressListener.STATE_START;
+ var WP_STATE_DOC = Ci.nsIWebProgressListener.STATE_IS_DOCUMENT;
+ var WP_STATE_START_DOC = WP_STATE_START | WP_STATE_DOC;
+
+ if ((aFlags & WP_STATE_START_DOC) == WP_STATE_START_DOC
+ && aRequest instanceof Ci.nsIChannel
+ && !(aRequest.loadFlags & aRequest.LOAD_INITIAL_DOCUMENT_URI)
+ && aRequest.URI.spec == "about:blank") {
+ torbutton_log(3, "Passing on about:blank");
+ return 0;
+ }
+
if(aProgress) {
try {
DOMWindow = aProgress.DOMWindow;
@@ -2814,7 +2828,7 @@
DOMWindow = null;
}
}
-
+
if(!DOMWindow) {
try {
if(aRequest.notificationCallbacks) {
@@ -2970,25 +2984,25 @@
onStateChange: function(aProgress, aRequest, aFlag, aStatus)
{
torbutton_eclog(1, 'State change()');
- return torbutton_check_progress(aProgress, aRequest);
+ return torbutton_check_progress(aProgress, aRequest, aFlag);
},
onLocationChange: function(aProgress, aRequest, aURI)
{
torbutton_eclog(1, 'onLocationChange: '+aURI.asciiSpec);
- return torbutton_check_progress(aProgress, aRequest);
+ return torbutton_check_progress(aProgress, aRequest, 0);
},
onProgressChange: function(aProgress, aRequest, curSelfProgress, maxSelfProgress, curTotalProgress, maxTotalProgress)
{
torbutton_eclog(1, 'called progressChange');
- return torbutton_check_progress(aProgress, aRequest);
+ return torbutton_check_progress(aProgress, aRequest, 0);
},
onStatusChange: function(aProgress, aRequest, stat, message)
{
torbutton_eclog(1, 'called progressChange');
- return torbutton_check_progress(aProgress, aRequest);
+ return torbutton_check_progress(aProgress, aRequest, 0);
},
onSecurityChange: function() {return 0;},