Bug 878692 - Form history should use FormHistory.jsm instead of nsIFormHistory2. r=wesj

This commit is contained in:
Margaret Leibovic 2013-06-04 15:59:50 -07:00
parent 2c7f4e9985
commit 34288bd4dd
2 changed files with 29 additions and 12 deletions

View File

@ -63,6 +63,9 @@ XPCOMUtils.defineLazyGetter(this, "Prompt", function() {
return temp.Prompt;
});
XPCOMUtils.defineLazyModuleGetter(this, "FormHistory",
"resource://gre/modules/FormHistory.jsm");
XPCOMUtils.defineLazyServiceGetter(this, "uuidgen",
"@mozilla.org/uuid-generator;1",
"nsIUUIDGenerator");
@ -352,8 +355,6 @@ var BrowserApp = {
// Init LoginManager
Cc["@mozilla.org/login-manager;1"].getService(Ci.nsILoginManager);
// Init FormHistory
Cc["@mozilla.org/satchel/form-history;1"].getService(Ci.nsIFormHistory2);
let url = null;
let pinned = false;
@ -1458,9 +1459,8 @@ var BrowserApp = {
}
case "FormHistory:Init": {
let fh = Cc["@mozilla.org/satchel/form-history;1"].getService(Ci.nsIFormHistory2);
// Force creation/upgrade of formhistory.sqlite
let db = fh.DBConnection;
FormHistory.count({});
Services.obs.removeObserver(this, "FormHistory:Init");
break;
}

View File

@ -5,8 +5,13 @@
let Cc = Components.classes;
let Ci = Components.interfaces;
let Cu = Components.utils;
Components.utils.import("resource://gre/modules/Services.jsm");
Cu.import("resource://gre/modules/Services.jsm");
Cu.import("resource://gre/modules/XPCOMUtils.jsm");
XPCOMUtils.defineLazyModuleGetter(this, "FormHistory",
"resource://gre/modules/FormHistory.jsm");
function dump(a) {
Cc["@mozilla.org/consoleservice;1"].getService(Ci.nsIConsoleService).logStringMessage(a);
@ -49,8 +54,16 @@ function Sanitizer() {}
Sanitizer.prototype = {
clearItem: function (aItemName)
{
if (this.items[aItemName].canClear)
this.items[aItemName].clear();
let item = this.items[aItemName];
let canClear = item.canClear;
if (typeof canClear == "function") {
canClear(function clearCallback(aCanClear) {
if (aCanClear)
item.clear();
});
} else if (canClear) {
item.clear();
}
},
items: {
@ -171,14 +184,18 @@ Sanitizer.prototype = {
}
}
var formHistory = Cc["@mozilla.org/satchel/form-history;1"].getService(Ci.nsIFormHistory2);
formHistory.removeAllEntries();
FormHistory.update({ op: "remove" });
},
get canClear()
canClear: function (aCallback)
{
var formHistory = Cc["@mozilla.org/satchel/form-history;1"].getService(Ci.nsIFormHistory2);
return formHistory.hasEntries;
let count = 0;
let countDone = {
handleResult: function(aResult) { count = aResult; },
handleError: function(aError) { Cu.reportError(aError); },
handleCompletion: function(aReason) { aCallback(aReason == 0 && count > 0); }
};
FormHistory.count({}, countDone);
}
},