aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpapush2021-04-29 15:50:26 +0200
committerpapush2021-04-29 15:50:26 +0200
commitff4d941f195f6359ee9715d16832c6af749a9045 (patch)
tree400552fc837ad47c2143ad865ffea424318023d0
parent7d21c850b011d53b73de8037f49009912440b7d9 (diff)
fix redirector prefs
by dynamically creating getters and setters instead of using the now gone watch and unwatch methods
-rw-r--r--chrome/js/redirectorprefs.js57
1 files changed, 41 insertions, 16 deletions
diff --git a/chrome/js/redirectorprefs.js b/chrome/js/redirectorprefs.js
index 75ef936..a0cd366 100644
--- a/chrome/js/redirectorprefs.js
+++ b/chrome/js/redirectorprefs.js
@@ -1,12 +1,37 @@
var EXPORTED_SYMBOLS = ['RedirectorPrefs'];
function RedirectorPrefs() {
- this.init();
+ this.init();
}
RedirectorPrefs.prototype = {
-
_listeners : null,
+
+ watch : function(prop_name, cb) {
+ Object.defineProperty(this, prop_name, {
+ set: function(val) {
+ cb(prop_name, null, val);
+ },
+ get: function() {
+ let pb = this._prefBranch;
+ switch (pb.getPrefType(prop_name)) {
+ case pb.PREF_STRING:
+ return pb.getCharPref(prop_name);
+ break;
+ case pb.PREF_INT:
+ return pb.getIntPref(prop_name);
+ break;
+ case pb.PREF_BOOL:
+ return pb.getBoolPref(prop_name);
+ break;
+ }
+ }});
+ },
+
+ unwatch : function(prop_name) {
+ delete this[prop_name];
+ },
+
init : function() {
this._prefBranch = Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefService).getBranch("extensions.redirector.");
this.reload();
@@ -18,20 +43,20 @@ RedirectorPrefs.prototype = {
this._listeners = null;
this.service.removeObserver('extensions.redirector', this);
},
-
+
reload : function(addWatch) {
var b = this._prefBranch;
for each (var name in b.getChildList('')){
this.unwatch(name);
- var type = b.getPrefType(name);
- if (type == b.PREF_STRING) {
- this[name] = b.getCharPref(name);
- } else if (type == b.PREF_INT) {
- this[name] = b.getIntPref(name);
- } else if (type == b.PREF_BOOL) {
- this[name] = b.getBoolPref(name);
- }
-
+ // var type = b.getPrefType(name);
+ // if (type == b.PREF_STRING) {
+ // this[name] = b.getCharPref(name);
+ // } else if (type == b.PREF_INT) {
+ // this[name] = b.getIntPref(name);
+ // } else if (type == b.PREF_BOOL) {
+ // this[name] = b.getBoolPref(name);
+ // }
+
this.watch(name, function(id,oldval,newval) {
var type = b.getPrefType(id);
if (type == b.PREF_STRING) {
@@ -46,7 +71,7 @@ RedirectorPrefs.prototype = {
});
}
},
-
+
get service() {
return Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefBranchInternal);
},
@@ -57,14 +82,14 @@ RedirectorPrefs.prototype = {
}
this.reload(false);
for each (var listener in this._listeners) {
- listener && listener.changedPrefs && listener.changedPrefs(this);
+ listener && listener.changedPrefs && listener.changedPrefs(this);
}
},
addListener : function(listener) {
this._listeners.push(listener);
},
-
+
removeListener : function(listener) {
for (var i = 0; i < this._listeners.length; i++) {
this._listeners.splice(i,1);
@@ -73,4 +98,4 @@ RedirectorPrefs.prototype = {
}
}
},
-} \ No newline at end of file
+}