зеркало из https://github.com/mozilla/pjs.git
Bug 460235 - Additional search service Ts improvements. r=gavin
This commit is contained in:
Родитель
80dc8a2a66
Коммит
0d4421b4c2
|
@ -92,7 +92,7 @@ const CACHE_INVALIDATION_DELAY = 1000;
|
||||||
|
|
||||||
// Current cache version. This should be incremented if the format of the cache
|
// Current cache version. This should be incremented if the format of the cache
|
||||||
// file is modified.
|
// file is modified.
|
||||||
const CACHE_VERSION = 1;
|
const CACHE_VERSION = 2;
|
||||||
|
|
||||||
const ICON_DATAURL_PREFIX = "data:image/x-icon;base64,";
|
const ICON_DATAURL_PREFIX = "data:image/x-icon;base64,";
|
||||||
|
|
||||||
|
@ -256,9 +256,30 @@ var LOG = function(){};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Presents an assertion dialog in non-release builds and throws.
|
||||||
|
* @param message
|
||||||
|
* A message to display
|
||||||
|
* @param resultCode
|
||||||
|
* The NS_ERROR_* value to throw.
|
||||||
|
* @throws resultCode
|
||||||
|
*/
|
||||||
function ERROR(message, resultCode) {
|
function ERROR(message, resultCode) {
|
||||||
NS_ASSERT(false, SEARCH_LOG_PREFIX + message);
|
NS_ASSERT(false, SEARCH_LOG_PREFIX + message);
|
||||||
throw resultCode;
|
throw Components.Exception(message, resultCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Logs the failure message (if browser.search.log is enabled) and throws.
|
||||||
|
* @param message
|
||||||
|
* A message to display
|
||||||
|
* @param resultCode
|
||||||
|
* The NS_ERROR_* value to throw.
|
||||||
|
* @throws resultCode or NS_ERROR_INVALID_ARG if resultCode isn't specified.
|
||||||
|
*/
|
||||||
|
function FAIL(message, resultCode) {
|
||||||
|
LOG(message);
|
||||||
|
throw Components.Exception(message, resultCode || Cr.NS_ERROR_INVALID_ARG);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -275,37 +296,7 @@ function ERROR(message, resultCode) {
|
||||||
function ENSURE_WARN(assertion, message, resultCode) {
|
function ENSURE_WARN(assertion, message, resultCode) {
|
||||||
NS_ASSERT(assertion, SEARCH_LOG_PREFIX + message);
|
NS_ASSERT(assertion, SEARCH_LOG_PREFIX + message);
|
||||||
if (!assertion)
|
if (!assertion)
|
||||||
throw resultCode;
|
throw Components.Exception(message, resultCode);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Ensures an assertion is met before continuing, but does not warn the user.
|
|
||||||
* Used to handle normal failure conditions.
|
|
||||||
* @param assertion
|
|
||||||
* An assertion that must be met
|
|
||||||
* @param message
|
|
||||||
* A message to display if the assertion is not met
|
|
||||||
* @param resultCode
|
|
||||||
* The NS_ERROR_* value to throw if the assertion is not met
|
|
||||||
* @throws resultCode
|
|
||||||
*/
|
|
||||||
function ENSURE(assertion, message, resultCode) {
|
|
||||||
if (!assertion) {
|
|
||||||
LOG(message);
|
|
||||||
throw resultCode;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Ensures an argument assertion is met before continuing.
|
|
||||||
* @param assertion
|
|
||||||
* An argument assertion that must be met
|
|
||||||
* @param message
|
|
||||||
* A message to display if the assertion is not met
|
|
||||||
* @throws NS_ERROR_INVALID_ARG for invalid arguments
|
|
||||||
*/
|
|
||||||
function ENSURE_ARG(assertion, message) {
|
|
||||||
ENSURE(assertion, message, Cr.NS_ERROR_INVALID_ARG);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function loadListener(aChannel, aEngine, aCallback) {
|
function loadListener(aChannel, aEngine, aCallback) {
|
||||||
|
@ -418,8 +409,8 @@ loadListener.prototype = {
|
||||||
* @throws NS_ERROR_INVALID_ARG if aLocalNameArray or aNameSpaceArray are null.
|
* @throws NS_ERROR_INVALID_ARG if aLocalNameArray or aNameSpaceArray are null.
|
||||||
*/
|
*/
|
||||||
function checkNameSpace(aElement, aLocalNameArray, aNameSpaceArray) {
|
function checkNameSpace(aElement, aLocalNameArray, aNameSpaceArray) {
|
||||||
ENSURE_ARG(aLocalNameArray && aNameSpaceArray, "missing aLocalNameArray or \
|
if (!aLocalNameArray || !aNameSpaceArray)
|
||||||
aNameSpaceArray for checkNameSpace");
|
FAIL("missing aLocalNameArray or aNameSpaceArray for checkNameSpace");
|
||||||
return (aElement &&
|
return (aElement &&
|
||||||
(aLocalNameArray.indexOf(aElement.localName) != -1) &&
|
(aLocalNameArray.indexOf(aElement.localName) != -1) &&
|
||||||
(aNameSpaceArray.indexOf(aElement.namespaceURI) != -1));
|
(aNameSpaceArray.indexOf(aElement.namespaceURI) != -1));
|
||||||
|
@ -461,7 +452,8 @@ function makeURI(aURLSpec, aCharset) {
|
||||||
*/
|
*/
|
||||||
let _dirSvc = null;
|
let _dirSvc = null;
|
||||||
function getDir(aKey, aIFace) {
|
function getDir(aKey, aIFace) {
|
||||||
ENSURE_ARG(aKey, "getDir requires a directory key!");
|
if (!aKey)
|
||||||
|
FAIL("getDir requires a directory key!");
|
||||||
|
|
||||||
if (!_dirSvc)
|
if (!_dirSvc)
|
||||||
_dirSvc = Cc["@mozilla.org/file/directory_service;1"].
|
_dirSvc = Cc["@mozilla.org/file/directory_service;1"].
|
||||||
|
@ -584,8 +576,8 @@ function sherlockBytesToLines(aBytes, aCharsetCode) {
|
||||||
var charset = fileCharsetFromCode(aCharsetCode);
|
var charset = fileCharsetFromCode(aCharsetCode);
|
||||||
|
|
||||||
var dataString = bytesToString(aBytes, charset);
|
var dataString = bytesToString(aBytes, charset);
|
||||||
ENSURE(dataString, "sherlockBytesToLines: Couldn't convert byte array!",
|
if (!dataString)
|
||||||
Cr.NS_ERROR_FAILURE);
|
FAIL("sherlockBytesToLines: Couldn't convert byte array!", Cr.NS_ERROR_FAILURE);
|
||||||
|
|
||||||
// Split the string into lines, and filter out comments and
|
// Split the string into lines, and filter out comments and
|
||||||
// whitespace-only lines
|
// whitespace-only lines
|
||||||
|
@ -726,8 +718,8 @@ function notifyAction(aEngine, aVerb) {
|
||||||
* Simple object representing a name/value pair.
|
* Simple object representing a name/value pair.
|
||||||
*/
|
*/
|
||||||
function QueryParameter(aName, aValue) {
|
function QueryParameter(aName, aValue) {
|
||||||
ENSURE_ARG(aName && (aValue != null),
|
if (!aName || (aValue == null))
|
||||||
"missing name or value for QueryParameter!");
|
FAIL("missing name or value for QueryParameter!");
|
||||||
|
|
||||||
this.name = aName;
|
this.name = aName;
|
||||||
this.value = aValue;
|
this.value = aValue;
|
||||||
|
@ -821,14 +813,14 @@ function createStatement (dbconn, sql) {
|
||||||
* @throws NS_ERROR_NOT_IMPLEMENTED if aType is unsupported.
|
* @throws NS_ERROR_NOT_IMPLEMENTED if aType is unsupported.
|
||||||
*/
|
*/
|
||||||
function EngineURL(aType, aMethod, aTemplate) {
|
function EngineURL(aType, aMethod, aTemplate) {
|
||||||
ENSURE_ARG(aType && aMethod && aTemplate,
|
if (!aType || !aMethod || !aTemplate)
|
||||||
"missing type, method or template for EngineURL!");
|
FAIL("missing type, method or template for EngineURL!");
|
||||||
|
|
||||||
var method = aMethod.toUpperCase();
|
var method = aMethod.toUpperCase();
|
||||||
var type = aType.toLowerCase();
|
var type = aType.toLowerCase();
|
||||||
|
|
||||||
ENSURE_ARG(method == "GET" || method == "POST",
|
if (method != "GET" && method != "POST")
|
||||||
"method passed to EngineURL must be \"GET\" or \"POST\"");
|
FAIL("method passed to EngineURL must be \"GET\" or \"POST\"");
|
||||||
|
|
||||||
this.type = type;
|
this.type = type;
|
||||||
this.method = method;
|
this.method = method;
|
||||||
|
@ -837,8 +829,8 @@ function EngineURL(aType, aMethod, aTemplate) {
|
||||||
this.mozparams = {};
|
this.mozparams = {};
|
||||||
|
|
||||||
var templateURI = makeURI(aTemplate);
|
var templateURI = makeURI(aTemplate);
|
||||||
ENSURE(templateURI, "new EngineURL: template is not a valid URI!",
|
if (!templateURI)
|
||||||
Cr.NS_ERROR_FAILURE);
|
FAIL("new EngineURL: template is not a valid URI!", Cr.NS_ERROR_FAILURE);
|
||||||
|
|
||||||
switch (templateURI.scheme) {
|
switch (templateURI.scheme) {
|
||||||
case "http":
|
case "http":
|
||||||
|
@ -849,8 +841,7 @@ function EngineURL(aType, aMethod, aTemplate) {
|
||||||
this.template = aTemplate;
|
this.template = aTemplate;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ENSURE(false, "new EngineURL: template uses invalid scheme!",
|
FAIL("new EngineURL: template uses invalid scheme!", Cr.NS_ERROR_FAILURE);
|
||||||
Cr.NS_ERROR_FAILURE);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EngineURL.prototype = {
|
EngineURL.prototype = {
|
||||||
|
@ -901,7 +892,7 @@ EngineURL.prototype = {
|
||||||
return new Submission(makeURI(url), postData);
|
return new Submission(makeURI(url), postData);
|
||||||
},
|
},
|
||||||
|
|
||||||
_initWithJSON: function SRC_EURL__initWithJSON(aJson, aIsDefault) {
|
_initWithJSON: function SRC_EURL__initWithJSON(aJson, aEngine) {
|
||||||
if (!aJson.params)
|
if (!aJson.params)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -909,7 +900,7 @@ EngineURL.prototype = {
|
||||||
let param = aJson.params[i];
|
let param = aJson.params[i];
|
||||||
if (param.mozparam) {
|
if (param.mozparam) {
|
||||||
if (param.condition == "defaultEngine") {
|
if (param.condition == "defaultEngine") {
|
||||||
if (aIsDefault)
|
if (aEngine._isDefaultEngine())
|
||||||
this.addParam(param.name, param.trueValue);
|
this.addParam(param.name, param.trueValue);
|
||||||
else
|
else
|
||||||
this.addParam(param.name, param.falseValue);
|
this.addParam(param.name, param.falseValue);
|
||||||
|
@ -989,7 +980,9 @@ function Engine(aLocation, aSourceDataType, aIsReadOnly) {
|
||||||
this._readOnly = aIsReadOnly;
|
this._readOnly = aIsReadOnly;
|
||||||
this._urls = [];
|
this._urls = [];
|
||||||
|
|
||||||
if (aLocation instanceof Ci.nsILocalFile) {
|
if (aLocation.cached) {
|
||||||
|
this._file = aLocation.value;
|
||||||
|
} else if (aLocation instanceof Ci.nsILocalFile) {
|
||||||
// we already have a file (e.g. loading engines from disk)
|
// we already have a file (e.g. loading engines from disk)
|
||||||
this._file = aLocation;
|
this._file = aLocation;
|
||||||
} else if (aLocation instanceof Ci.nsIURI) {
|
} else if (aLocation instanceof Ci.nsIURI) {
|
||||||
|
@ -1028,7 +1021,18 @@ Engine.prototype = {
|
||||||
// engine.
|
// engine.
|
||||||
_engineToUpdate: null,
|
_engineToUpdate: null,
|
||||||
// The file from which the plugin was loaded.
|
// The file from which the plugin was loaded.
|
||||||
_file: null,
|
__file: null,
|
||||||
|
get _file() {
|
||||||
|
if (this.__file && !(this.__file instanceof Ci.nsILocalFile)) {
|
||||||
|
let file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile);
|
||||||
|
file.persistentDescriptor = this.__file;
|
||||||
|
return this.__file = file;
|
||||||
|
}
|
||||||
|
return this.__file;
|
||||||
|
},
|
||||||
|
set _file(aValue) {
|
||||||
|
this.__file = aValue;
|
||||||
|
},
|
||||||
// Set to true if the engine has a preferred icon (an icon that should not be
|
// Set to true if the engine has a preferred icon (an icon that should not be
|
||||||
// overridden by a non-preferred icon).
|
// overridden by a non-preferred icon).
|
||||||
_hasPreferredIcon: null,
|
_hasPreferredIcon: null,
|
||||||
|
@ -1070,9 +1074,8 @@ Engine.prototype = {
|
||||||
* of lines in the engine's data field.
|
* of lines in the engine's data field.
|
||||||
*/
|
*/
|
||||||
_initFromFile: function SRCH_ENG_initFromFile() {
|
_initFromFile: function SRCH_ENG_initFromFile() {
|
||||||
ENSURE(this._file && this._file.exists(),
|
if (!this._file || !this._file.exists())
|
||||||
"File must exist before calling initFromFile!",
|
FAIL("File must exist before calling initFromFile!", Cr.NS_ERROR_UNEXPECTED);
|
||||||
Cr.NS_ERROR_UNEXPECTED);
|
|
||||||
|
|
||||||
var fileInStream = Cc["@mozilla.org/network/file-input-stream;1"].
|
var fileInStream = Cc["@mozilla.org/network/file-input-stream;1"].
|
||||||
createInstance(Ci.nsIFileInputStream);
|
createInstance(Ci.nsIFileInputStream);
|
||||||
|
@ -1421,8 +1424,7 @@ Engine.prototype = {
|
||||||
this._parseAsOpenSearch();
|
this._parseAsOpenSearch();
|
||||||
|
|
||||||
} else
|
} else
|
||||||
ENSURE(false, this._location + " is not a valid search plugin.",
|
FAIL(this._location + " is not a valid search plugin.", Cr.NS_ERROR_FAILURE);
|
||||||
Cr.NS_ERROR_FAILURE);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case SEARCH_DATA_TEXT:
|
case SEARCH_DATA_TEXT:
|
||||||
|
@ -1477,8 +1479,8 @@ Engine.prototype = {
|
||||||
try {
|
try {
|
||||||
var url = new EngineURL(type, method, template);
|
var url = new EngineURL(type, method, template);
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
LOG("_parseURL: failed to add " + template + " as a URL");
|
FAIL("_parseURL: failed to add " + template + " as a URL",
|
||||||
throw Cr.NS_ERROR_FAILURE;
|
Cr.NS_ERROR_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (var i = 0; i < aElement.childNodes.length; ++i) {
|
for (var i = 0; i < aElement.childNodes.length; ++i) {
|
||||||
|
@ -1600,12 +1602,10 @@ Engine.prototype = {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ENSURE(this.name && (this._urls.length > 0),
|
if (!this.name || (this._urls.length == 0))
|
||||||
"_parseAsOpenSearch: No name, or missing URL!",
|
FAIL("_parseAsOpenSearch: No name, or missing URL!", Cr.NS_ERROR_FAILURE);
|
||||||
Cr.NS_ERROR_FAILURE);
|
if (!this.supportsResponseType(URLTYPE_SEARCH_HTML))
|
||||||
ENSURE(this.supportsResponseType(URLTYPE_SEARCH_HTML),
|
FAIL("_parseAsOpenSearch: No text/html result type!", Cr.NS_ERROR_FAILURE);
|
||||||
"_parseAsOpenSearch: No text/html result type!",
|
|
||||||
Cr.NS_ERROR_FAILURE);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1828,8 +1828,8 @@ Engine.prototype = {
|
||||||
}
|
}
|
||||||
|
|
||||||
function err(aErr) {
|
function err(aErr) {
|
||||||
LOG("_parseAsSherlock::err: Sherlock param error:\n" + aErr);
|
FAIL("_parseAsSherlock::err: Sherlock param error:\n" + aErr,
|
||||||
throw Cr.NS_ERROR_FAILURE;
|
Cr.NS_ERROR_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// First try converting our byte array using the default Sherlock encoding.
|
// First try converting our byte array using the default Sherlock encoding.
|
||||||
|
@ -1923,6 +1923,7 @@ Engine.prototype = {
|
||||||
* Init from a JSON record.
|
* Init from a JSON record.
|
||||||
**/
|
**/
|
||||||
_initWithJSON: function SRCH_ENG__initWithJSON(aJson) {
|
_initWithJSON: function SRCH_ENG__initWithJSON(aJson) {
|
||||||
|
this.__id = aJson._id;
|
||||||
this._name = aJson._name;
|
this._name = aJson._name;
|
||||||
this._description = aJson.description;
|
this._description = aJson.description;
|
||||||
if (aJson._hasPreferredIcon == undefined)
|
if (aJson._hasPreferredIcon == undefined)
|
||||||
|
@ -1946,7 +1947,7 @@ Engine.prototype = {
|
||||||
let url = aJson._urls[i];
|
let url = aJson._urls[i];
|
||||||
let engineURL = new EngineURL(url.type || URLTYPE_SEARCH_HTML,
|
let engineURL = new EngineURL(url.type || URLTYPE_SEARCH_HTML,
|
||||||
url.method || "GET", url.template);
|
url.method || "GET", url.template);
|
||||||
engineURL._initWithJSON(url, this._isDefaultEngine());
|
engineURL._initWithJSON(url, this);
|
||||||
this._urls.push(engineURL);
|
this._urls.push(engineURL);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -1960,6 +1961,7 @@ Engine.prototype = {
|
||||||
**/
|
**/
|
||||||
_serializeToJSON: function SRCH_ENG__serializeToJSON(aFilter) {
|
_serializeToJSON: function SRCH_ENG__serializeToJSON(aFilter) {
|
||||||
var json = {
|
var json = {
|
||||||
|
_id: this._id,
|
||||||
_name: this._name,
|
_name: this._name,
|
||||||
description: this.description,
|
description: this.description,
|
||||||
filePath: this._file.QueryInterface(Ci.nsILocalFile).persistentDescriptor,
|
filePath: this._file.QueryInterface(Ci.nsILocalFile).persistentDescriptor,
|
||||||
|
@ -2100,11 +2102,10 @@ Engine.prototype = {
|
||||||
* the file cannot be removed.
|
* the file cannot be removed.
|
||||||
*/
|
*/
|
||||||
_remove: function SRCH_ENG_remove() {
|
_remove: function SRCH_ENG_remove() {
|
||||||
ENSURE(!this._readOnly, "Can't remove read only engine!",
|
if (this._readOnly)
|
||||||
Cr.NS_ERROR_FAILURE);
|
FAIL("Can't remove read only engine!", Cr.NS_ERROR_FAILURE);
|
||||||
ENSURE(this._file && this._file.exists(),
|
if (!this._file || !this._file.exists())
|
||||||
"Can't remove engine: file doesn't exist!",
|
FAIL("Can't remove engine: file doesn't exist!", Cr.NS_ERROR_FILE_NOT_FOUND);
|
||||||
Cr.NS_ERROR_FILE_NOT_FOUND);
|
|
||||||
|
|
||||||
this._file.remove(false);
|
this._file.remove(false);
|
||||||
},
|
},
|
||||||
|
@ -2165,18 +2166,21 @@ Engine.prototype = {
|
||||||
|
|
||||||
// The file that the plugin is loaded from is a unique identifier for it. We
|
// The file that the plugin is loaded from is a unique identifier for it. We
|
||||||
// use this as the identifier to store data in the sqlite database
|
// use this as the identifier to store data in the sqlite database
|
||||||
|
__id: null,
|
||||||
get _id() {
|
get _id() {
|
||||||
|
if (!this.__id) {
|
||||||
ENSURE_WARN(this._file, "No _file for id!", Cr.NS_ERROR_FAILURE);
|
ENSURE_WARN(this._file, "No _file for id!", Cr.NS_ERROR_FAILURE);
|
||||||
|
|
||||||
if (this._isInProfile)
|
if (this._isInProfile)
|
||||||
return "[profile]/" + this._file.leafName;
|
return this.__id = "[profile]/" + this._file.leafName;
|
||||||
|
|
||||||
if (this._isInAppDir)
|
if (this._isInAppDir)
|
||||||
return "[app]/" + this._file.leafName;
|
return this.__id = "[app]/" + this._file.leafName;
|
||||||
|
|
||||||
// We're not in the profile or appdir, so this must be an extension-shipped
|
// We're not in the profile or appdir, so this must be an extension-shipped
|
||||||
// plugin. Use the full path.
|
// plugin. Use the full path.
|
||||||
return this._file.path;
|
return this.__id = this._file.path;
|
||||||
|
}
|
||||||
|
return this.__id;
|
||||||
},
|
},
|
||||||
|
|
||||||
get _installLocation() {
|
get _installLocation() {
|
||||||
|
@ -2243,8 +2247,8 @@ Engine.prototype = {
|
||||||
|
|
||||||
// from nsISearchEngine
|
// from nsISearchEngine
|
||||||
addParam: function SRCH_ENG_addParam(aName, aValue, aResponseType) {
|
addParam: function SRCH_ENG_addParam(aName, aValue, aResponseType) {
|
||||||
ENSURE_ARG(aName && (aValue != null),
|
if (!aName || (aValue === null))
|
||||||
"missing name or value for nsISearchEngine::addParam!");
|
FAIL("missing name or value for nsISearchEngine::addParam!");
|
||||||
ENSURE_WARN(!this._readOnly,
|
ENSURE_WARN(!this._readOnly,
|
||||||
"called nsISearchEngine::addParam on a read-only engine!",
|
"called nsISearchEngine::addParam on a read-only engine!",
|
||||||
Cr.NS_ERROR_FAILURE);
|
Cr.NS_ERROR_FAILURE);
|
||||||
|
@ -2252,8 +2256,8 @@ Engine.prototype = {
|
||||||
aResponseType = URLTYPE_SEARCH_HTML;
|
aResponseType = URLTYPE_SEARCH_HTML;
|
||||||
|
|
||||||
var url = this._getURLOfType(aResponseType);
|
var url = this._getURLOfType(aResponseType);
|
||||||
|
if (!url)
|
||||||
ENSURE(url, "Engine object has no URL for response type " + aResponseType,
|
FAIL("Engine object has no URL for response type " + aResponseType,
|
||||||
Cr.NS_ERROR_FAILURE);
|
Cr.NS_ERROR_FAILURE);
|
||||||
|
|
||||||
url.addParam(aName, aValue);
|
url.addParam(aName, aValue);
|
||||||
|
@ -2555,9 +2559,8 @@ SearchService.prototype = {
|
||||||
LOG("_loadEnginesFromCache: Loading from cache. " + engines.length + " engines to load.");
|
LOG("_loadEnginesFromCache: Loading from cache. " + engines.length + " engines to load.");
|
||||||
for (let i = 0; i < engines.length; i++) {
|
for (let i = 0; i < engines.length; i++) {
|
||||||
let json = engines[i];
|
let json = engines[i];
|
||||||
let file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile);
|
let engine = new Engine({cached: true, value: json.filePath}, json._dataType,
|
||||||
file.persistentDescriptor = json.filePath;
|
json._readOnly);
|
||||||
let engine = new Engine(file, json._dataType, json._readOnly);
|
|
||||||
engine._initWithJSON(json);
|
engine._initWithJSON(json);
|
||||||
this._addEngineToStore(engine);
|
this._addEngineToStore(engine);
|
||||||
}
|
}
|
||||||
|
@ -2764,9 +2767,8 @@ SearchService.prototype = {
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
// Just bail. Engines that can't be backed up won't be converted, but
|
// Just bail. Engines that can't be backed up won't be converted, but
|
||||||
// engines that aren't converted are loaded as readonly.
|
// engines that aren't converted are loaded as readonly.
|
||||||
LOG("_convertSherlockFile: Couldn't back up " + oldSherlockFile.path +
|
FAIL("_convertSherlockFile: Couldn't back up " + oldSherlockFile.path +
|
||||||
":\n" + ex);
|
":\n" + ex, Cr.NS_ERROR_FAILURE);
|
||||||
throw Cr.NS_ERROR_FAILURE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Rename the file, but don't clobber existing files
|
// Rename the file, but don't clobber existing files
|
||||||
|
@ -2948,12 +2950,14 @@ SearchService.prototype = {
|
||||||
addEngineWithDetails: function SRCH_SVC_addEWD(aName, aIconURL, aAlias,
|
addEngineWithDetails: function SRCH_SVC_addEWD(aName, aIconURL, aAlias,
|
||||||
aDescription, aMethod,
|
aDescription, aMethod,
|
||||||
aTemplate) {
|
aTemplate) {
|
||||||
ENSURE_ARG(aName, "Invalid name passed to addEngineWithDetails!");
|
if (!aName)
|
||||||
ENSURE_ARG(aMethod, "Invalid method passed to addEngineWithDetails!");
|
FAIL("Invalid name passed to addEngineWithDetails!");
|
||||||
ENSURE_ARG(aTemplate, "Invalid template passed to addEngineWithDetails!");
|
if (!aMethod)
|
||||||
|
FAIL("Invalid method passed to addEngineWithDetails!");
|
||||||
ENSURE(!this._engines[aName], "An engine with that name already exists!",
|
if (!aTemplate)
|
||||||
Cr.NS_ERROR_FILE_ALREADY_EXISTS);
|
FAIL("Invalid template passed to addEngineWithDetails!");
|
||||||
|
if (this._engines[aName])
|
||||||
|
FAIL("An engine with that name already exists!", Cr.NS_ERROR_FILE_ALREADY_EXISTS);
|
||||||
|
|
||||||
var engine = new Engine(getSanitizedFile(aName), SEARCH_DATA_XML, false);
|
var engine = new Engine(getSanitizedFile(aName), SEARCH_DATA_XML, false);
|
||||||
engine._initFromMetadata(aName, aIconURL, aAlias, aDescription,
|
engine._initFromMetadata(aName, aIconURL, aAlias, aDescription,
|
||||||
|
@ -2970,23 +2974,23 @@ SearchService.prototype = {
|
||||||
var engine = new Engine(uri, aDataType, false);
|
var engine = new Engine(uri, aDataType, false);
|
||||||
engine._initFromURI();
|
engine._initFromURI();
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
LOG("addEngine: Error adding engine:\n" + ex);
|
FAIL("addEngine: Error adding engine:\n" + ex, Cr.NS_ERROR_FAILURE);
|
||||||
throw Cr.NS_ERROR_FAILURE;
|
|
||||||
}
|
}
|
||||||
engine._setIcon(aIconURL, false);
|
engine._setIcon(aIconURL, false);
|
||||||
engine._confirm = aConfirm;
|
engine._confirm = aConfirm;
|
||||||
},
|
},
|
||||||
|
|
||||||
removeEngine: function SRCH_SVC_removeEngine(aEngine) {
|
removeEngine: function SRCH_SVC_removeEngine(aEngine) {
|
||||||
ENSURE_ARG(aEngine, "no engine passed to removeEngine!");
|
if (!aEngine)
|
||||||
|
FAIL("no engine passed to removeEngine!");
|
||||||
|
|
||||||
var engineToRemove = null;
|
var engineToRemove = null;
|
||||||
for (var e in this._engines)
|
for (var e in this._engines)
|
||||||
if (aEngine.wrappedJSObject == this._engines[e])
|
if (aEngine.wrappedJSObject == this._engines[e])
|
||||||
engineToRemove = this._engines[e];
|
engineToRemove = this._engines[e];
|
||||||
|
|
||||||
ENSURE(engineToRemove, "removeEngine: Can't find engine to remove!",
|
if (!engineToRemove)
|
||||||
Cr.NS_ERROR_FILE_NOT_FOUND);
|
FAIL("removeEngine: Can't find engine to remove!", Cr.NS_ERROR_FILE_NOT_FOUND);
|
||||||
|
|
||||||
if (engineToRemove == this.currentEngine)
|
if (engineToRemove == this.currentEngine)
|
||||||
this._currentEngine = null;
|
this._currentEngine = null;
|
||||||
|
@ -3009,8 +3013,8 @@ SearchService.prototype = {
|
||||||
|
|
||||||
// Remove the engine from _sortedEngines
|
// Remove the engine from _sortedEngines
|
||||||
var index = this._sortedEngines.indexOf(engineToRemove);
|
var index = this._sortedEngines.indexOf(engineToRemove);
|
||||||
ENSURE(index != -1, "Can't find engine to remove in _sortedEngines!",
|
if (index == -1)
|
||||||
Cr.NS_ERROR_FAILURE);
|
FAIL("Can't find engine to remove in _sortedEngines!", Cr.NS_ERROR_FAILURE);
|
||||||
this._sortedEngines.splice(index, 1);
|
this._sortedEngines.splice(index, 1);
|
||||||
|
|
||||||
// Remove the engine from the internal store
|
// Remove the engine from the internal store
|
||||||
|
@ -3024,18 +3028,18 @@ SearchService.prototype = {
|
||||||
},
|
},
|
||||||
|
|
||||||
moveEngine: function SRCH_SVC_moveEngine(aEngine, aNewIndex) {
|
moveEngine: function SRCH_SVC_moveEngine(aEngine, aNewIndex) {
|
||||||
ENSURE_ARG((aNewIndex < this._sortedEngines.length) && (aNewIndex >= 0),
|
if ((aNewIndex > this._sortedEngines.length) || (aNewIndex < 0))
|
||||||
"SRCH_SVC_moveEngine: Index out of bounds!");
|
FAIL("SRCH_SVC_moveEngine: Index out of bounds!");
|
||||||
ENSURE_ARG(aEngine instanceof Ci.nsISearchEngine,
|
if (!(aEngine instanceof Ci.nsISearchEngine))
|
||||||
"SRCH_SVC_moveEngine: Invalid engine passed to moveEngine!");
|
FAIL("SRCH_SVC_moveEngine: Invalid engine passed to moveEngine!");
|
||||||
ENSURE(!aEngine.hidden, "moveEngine: Can't move a hidden engine!",
|
if (aEngine.hidden)
|
||||||
Cr.NS_ERROR_FAILURE);
|
FAIL("moveEngine: Can't move a hidden engine!", Cr.NS_ERROR_FAILURE);
|
||||||
|
|
||||||
var engine = aEngine.wrappedJSObject;
|
var engine = aEngine.wrappedJSObject;
|
||||||
|
|
||||||
var currentIndex = this._sortedEngines.indexOf(engine);
|
var currentIndex = this._sortedEngines.indexOf(engine);
|
||||||
ENSURE(currentIndex != -1, "moveEngine: Can't find engine to move!",
|
if (currentIndex == -1)
|
||||||
Cr.NS_ERROR_UNEXPECTED);
|
FAIL("moveEngine: Can't find engine to move!", Cr.NS_ERROR_UNEXPECTED);
|
||||||
|
|
||||||
// Our callers only take into account non-hidden engines when calculating
|
// Our callers only take into account non-hidden engines when calculating
|
||||||
// aNewIndex, but we need to move it in the array of all engines, so we
|
// aNewIndex, but we need to move it in the array of all engines, so we
|
||||||
|
@ -3049,8 +3053,8 @@ SearchService.prototype = {
|
||||||
// This could be further simplified by having our caller pass in
|
// This could be further simplified by having our caller pass in
|
||||||
// newIndexEngine directly instead of aNewIndex.
|
// newIndexEngine directly instead of aNewIndex.
|
||||||
var newIndexEngine = this._getSortedEngines(false)[aNewIndex];
|
var newIndexEngine = this._getSortedEngines(false)[aNewIndex];
|
||||||
ENSURE(newIndexEngine, "moveEngine: Can't find engine to replace!",
|
if (!newIndexEngine)
|
||||||
Cr.NS_ERROR_UNEXPECTED);
|
FAIL("moveEngine: Can't find engine to replace!", Cr.NS_ERROR_UNEXPECTED);
|
||||||
|
|
||||||
for (var i = 0; i < this._sortedEngines.length; ++i) {
|
for (var i = 0; i < this._sortedEngines.length; ++i) {
|
||||||
if (newIndexEngine == this._sortedEngines[i])
|
if (newIndexEngine == this._sortedEngines[i])
|
||||||
|
@ -3096,12 +3100,12 @@ SearchService.prototype = {
|
||||||
return this._currentEngine;
|
return this._currentEngine;
|
||||||
},
|
},
|
||||||
set currentEngine(val) {
|
set currentEngine(val) {
|
||||||
ENSURE_ARG(val instanceof Ci.nsISearchEngine,
|
if (!(val instanceof Ci.nsISearchEngine))
|
||||||
"Invalid argument passed to currentEngine setter");
|
FAIL("Invalid argument passed to currentEngine setter");
|
||||||
|
|
||||||
var newCurrentEngine = this.getEngineByName(val.name);
|
var newCurrentEngine = this.getEngineByName(val.name);
|
||||||
ENSURE(newCurrentEngine, "Can't find engine in store!",
|
if (!newCurrentEngine)
|
||||||
Cr.NS_ERROR_UNEXPECTED);
|
FAIL("Can't find engine in store!", Cr.NS_ERROR_UNEXPECTED);
|
||||||
|
|
||||||
this._currentEngine = newCurrentEngine;
|
this._currentEngine = newCurrentEngine;
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче