[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] [torbutton/master 10/30] Fix bug 1219: Fix the toggle warning loop.
Author: Mike Perry <mikeperry-git@xxxxxxxxxx>
Date: Mon, 29 Mar 2010 18:25:54 -0700
Subject: Fix bug 1219: Fix the toggle warning loop.
Commit: 1612dfb32507ffa579915d12ca416a2b54bf62e8
It should now only display once per settings window close.
---
src/chrome/content/preferences.js | 11 +++++++++++
src/chrome/content/torbutton.js | 17 ++++++++++++++---
2 files changed, 25 insertions(+), 3 deletions(-)
diff --git a/src/chrome/content/preferences.js b/src/chrome/content/preferences.js
index 92f1742..a922d20 100644
--- a/src/chrome/content/preferences.js
+++ b/src/chrome/content/preferences.js
@@ -336,6 +336,17 @@ function torbutton_prefs_save(doc) {
var o_torprefs = torbutton_get_prefbranch('extensions.torbutton.');
var o_customprefs = torbutton_get_prefbranch('extensions.torbutton.custom.');
+ var wm = Components.classes["@mozilla.org/appshell/window-mediator;1"]
+ .getService(Components.interfaces.nsIWindowMediator);
+ var enumerator = wm.getEnumerator("navigator:browser");
+ while(enumerator.hasMoreElements()) {
+ var win = enumerator.getNext();
+ if(win != window && win.m_tb_is_main_window) {
+ torbutton_log(3, "Found main window for popup hack.");
+ win.torbutton_unique_pref_observer.did_toggle_warning = false;
+ }
+ }
+
o_torprefs.setBoolPref('display_panel', doc.getElementById('torbutton_displayStatusPanel').checked);
o_torprefs.setCharPref('panel_style', doc.getElementById('torbutton_panelStyle').value);
o_torprefs.setCharPref('settings_method', doc.getElementById('torbutton_settingsMethod').value);
diff --git a/src/chrome/content/torbutton.js b/src/chrome/content/torbutton.js
index ce7f4da..5540fad 100644
--- a/src/chrome/content/torbutton.js
+++ b/src/chrome/content/torbutton.js
@@ -67,6 +67,7 @@ var torbutton_unique_pref_observer =
this.forced_ua = false;
var pref_service = Components.classes["@mozilla.org/preferences-service;1"]
.getService(Components.interfaces.nsIPrefBranchInternal);
+ this.did_toggle_warning = false;
this._branch = pref_service.QueryInterface(Components.interfaces.nsIPrefBranchInternal);
this._branch.addObserver("extensions.torbutton", this, false);
this._branch.addObserver("network.proxy", this, false);
@@ -263,18 +264,22 @@ var torbutton_unique_pref_observer =
case "extensions.torbutton.block_tforms":
case "extensions.torbutton.block_cache":
case "extensions.torbutton.block_thwrite":
- if(m_tb_prefs.getBoolPref("extensions.torbutton.tor_enabled")) {
+ if(!this.did_toggle_warning &&
+ m_tb_prefs.getBoolPref("extensions.torbutton.tor_enabled")) {
var o_stringbundle = torbutton_get_stringbundle();
var warning = o_stringbundle.GetStringFromName("torbutton.popup.toggle.warning");
+ this.did_toggle_warning = true;
window.alert(warning);
}
break;
case "extensions.torbutton.block_nthwrite":
case "extensions.torbutton.block_ntforms":
- if(!m_tb_prefs.getBoolPref("extensions.torbutton.tor_enabled")) {
+ if(!this.did_toggle_warning &&
+ m_tb_prefs.getBoolPref("extensions.torbutton.tor_enabled")) {
var o_stringbundle = torbutton_get_stringbundle();
var warning = o_stringbundle.GetStringFromName("torbutton.popup.toggle.warning");
+ this.did_toggle_warning = true;
window.alert(warning);
}
break;
@@ -3461,8 +3466,14 @@ function torbutton_update_tags(win, new_loc) {
return;
//win.alert("No window found!");
}
- torbutton_log(2, "Got browser "+browser.contentWindow.location+" for: "
+
+ // This sometimes happens with CoolPreviews..
+ try {
+ torbutton_log(2, "Got browser "+browser.contentWindow.location+" for: "
+ win.location + ", under: "+win.top.location);
+ } catch(e) {
+ torbutton_log(4, "Missing content window? "+str(e));
+ }
// Base this tag off of proxies_applied, since we want to go
// by whatever the actual load proxy was
--
1.6.5