[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] [torbutton/master] Add some logs and a hack to attempt to fix bug 1152.



Author: Mike Perry <mikeperry-git@xxxxxxxxxx>
Date: Wed, 18 Nov 2009 15:59:29 -0800
Subject: Add some logs and a hack to attempt to fix bug 1152.
Commit: 39505586a8350e28d9b403b5c9cc27e6af8af6dc

---
 src/chrome/content/torbutton.js |   44 +++++++++++++++++++++++++++++++++-----
 1 files changed, 38 insertions(+), 6 deletions(-)

diff --git a/src/chrome/content/torbutton.js b/src/chrome/content/torbutton.js
index 5e956e0..60d04b0 100644
--- a/src/chrome/content/torbutton.js
+++ b/src/chrome/content/torbutton.js
@@ -1340,14 +1340,35 @@ function torbutton_close_on_toggle(mode) {
     }
 
     // TODO: muck around with browser.tabs.warnOnClose.. maybe..
-    torbutton_log(3, "Closing tabs");
+    torbutton_log(3, "Closing tabs...");
     var wm = Components.classes["@mozilla.org/appshell/window-mediator;1"]
         .getService(Components.interfaces.nsIWindowMediator);
     var enumerator = wm.getEnumerator("navigator:browser");
+    var closeWins = new Array();
     while(enumerator.hasMoreElements()) {
         var win = enumerator.getNext();
         var browser = win.getBrowser();
+
+        if(!browser) {
+          torbutton_log(3, "No browser..");
+          continue;
+        }
+
+        if(!browser.browsers) {
+          torbutton_log(3, "No browser.browsers..");
+          continue;
+        }
+
         var tabs = browser.browsers.length;
+
+        torbutton_log(3, "Length: "+browser.browsers.length);
+
+        if(!tabs) {
+          torbutton_log(2, "No tabs to close in this window.");
+          continue;
+        }
+
+
         var remove = new Array();
         for(var i = 0; i < tabs; i++) {
             if(browser.browsers[i].__tb_tor_fetched != mode) {
@@ -1356,21 +1377,32 @@ function torbutton_close_on_toggle(mode) {
         }
 
         for(var i = 0; i < remove.length; i++) {
+            if(!remove[i].linkedBrowser) {
+              torbutton_log(3, "Tab for "+remove[i].currentURI.spec+
+                      " has no linked browser. Hacking one in.");
+              remove[i].linkedBrowser = browser;
+            }
             browser.removeTab(remove[i]);
         }
 
-        torbutton_log(3, "Length: "+browser.browsers.length);
-
-        if(browser.browsers.length == 1 
+        if(browser.browsers.length == 1
                 && browser.browsers[0].__tb_tor_fetched != mode) {
             if(win != window) {
-                win.close();
+                closeWins.push(win);
             } else {
                 var newb = browser.addTab("about:blank");
                 browser.removeAllTabsBut(newb);
             }
         }
     }
+
+    torbutton_log(2, "Closing windows...");
+
+    for(var i = 0; i < closeWins.length; ++i) {
+      closeWins[i].close();
+    }
+
+    torbutton_log(3, "Closed all tabs");
 }
 
 
@@ -1479,11 +1511,11 @@ function torbutton_clear_history() {
                        .getService(Components.interfaces.nsIWindowMediator);
     var enumerator = wm.getEnumerator("navigator:browser");
     var js_enabled = m_tb_prefs.getBoolPref("javascript.enabled");
+    torbutton_log(2, "Clearing browser session history");
     while(enumerator.hasMoreElements()) {
         var win = enumerator.getNext();
         var browser = win.getBrowser();
         var browsers = browser.browsers;
-        torbutton_log(1, "Toggle window plugins");
 
         for (var i = 0; i < browsers.length; ++i) {
             var b = browser.browsers[i];
-- 
1.5.6.5