bug 337178 - hook up remote search suggestions, r=gavin, a=bonecho drivers

This commit is contained in:
mconnor%steelgryphon.com 2006-05-08 21:41:54 +00:00
Родитель 957ea17717
Коммит 87a363948c
6 изменённых файлов: 49 добавлений и 4 удалений

Просмотреть файл

@ -48,6 +48,7 @@ XPIDL_MODULE = browsersearch
XPIDLSRCS = nsIBrowserSearchService.idl
EXTRA_PP_COMPONENTS = nsSearchService.js
EXTRA_PP_COMPONENTS = nsSearchService.js \
nsSearchSuggestions.js
include $(topsrcdir)/config/rules.mk

Просмотреть файл

@ -108,6 +108,9 @@
Components.classes["@mozilla.org/observer-service;1"]
.getService(Components.interfaces.nsIObserverService);
os.addObserver(this, "browser-search-engine-modified", false);
// make sure we're using the right autocomplete
this._updateAutocompleteSearch();
]]></body>
</method>
@ -355,11 +358,31 @@
if (newIndex >= 0 && newIndex < this._engines.length)
this.currentEngine = this._engines[newIndex];
this._updateAutocompleteSearch()
aEvent.preventDefault();
aEvent.stopPropagation();
]]></body>
</method>
<method name="_updateAutocompleteSearch">
<body><![CDATA[
var autocompleteSearch = this.currentEngine.suggestionURI ?
"remote-url-suggestions" :
"form-history";
this._textbox.setAttribute("autocompletesearch", autocompleteSearch);
this._textbox.mSearchNames = null;
// Resetting the input property causes the field to notify
// the autocomplete controller that the search service(s) it must
// use have changed. We have no means of notifying it about this
// change directly.
this._textbox.mController.input = null;
this._textbox.mController.input = this._textbox;
]]></body>
</method>
<method name="handleSearchCommand">
<parameter name="aEvent"/>
<body><![CDATA[

Просмотреть файл

@ -41,7 +41,7 @@
interface nsIURI;
interface nsIInputStream;
[scriptable, uuid(ebe9f0f6-ca5a-415a-b578-82e2db61fb2a)]
[scriptable, uuid(58e4f602-a7c8-4cd1-9dca-716705e826ef)]
interface nsISearchSubmission : nsISupports
{
/**
@ -112,6 +112,11 @@ interface nsISearchEngine : nsISupports
*/
attribute boolean hidden;
/**
* A URI object for retrieving suggested searches
*/
readonly attribute nsIURI suggestionURI;
/**
* A nsIURI corresponding to the engine's icon, stored locally. May be null.
*/

Просмотреть файл

@ -383,11 +383,11 @@ function closeSafeOutputStream(aFOS) {
* The URL string from which to create an nsIURI.
* @returns an nsIURI object, or null if the creation of the URI failed.
*/
function makeURI(aURLSpec) {
function makeURI(aURLSpec, aCharset) {
var ios = Cc["@mozilla.org/network/io-service;1"].
getService(Ci.nsIIOService);
try {
return ios.newURI(aURLSpec, null, null);
return ios.newURI(aURLSpec, aCharset, null);
} catch (ex) { }
return null;
@ -1143,6 +1143,9 @@ Engine.prototype = {
case "InputEncoding":
this._queryCharset = child.textContent.toUpperCase();
break;
case "SuggestionURL":
this._createSuggestionURI(child.textContent);
break;
}
}
ENSURE(this.name && (this._urls.length > 0),
@ -1509,6 +1512,13 @@ Engine.prototype = {
closeSafeOutputStream(fos);
},
_createSuggestionURI: function SRCH_ENG_createSuggestionURI (aURLString) {
var suggestionURI = makeURI(aURLString, this._queryCharset);
if (suggestionURI &&
(suggestionURI.schemeIs("http") || suggestionURI.schemeIs("https")))
this._suggestionURI = suggestionURI;
},
/**
* Remove the engine's file from disk. The search service calls this once it
* removes the engine from its internal store. This function will throw if
@ -1557,6 +1567,10 @@ Engine.prototype = {
}
},
get suggestionURI() {
return this._suggestionURI;
},
get iconURI() {
return this._iconURI;
},

Просмотреть файл

@ -3,6 +3,7 @@
<os:Description>Google Search</os:Description>
<os:InputEncoding>UTF-8</os:InputEncoding>
<os:Image width="16" height="16"></os:Image>
<SuggestionURL>http://www.google.com/complete/search?csv=t&amp;qu=</SuggestionURL>
<os:Url type="text/html" method="GET" template="http://www.google.com/search">
<os:Param name="q" value="{searchTerms}"/>
<os:Param name="start" value="0"/>

Просмотреть файл

@ -2,6 +2,7 @@
<os:ShortName>Yahoo</os:ShortName>
<os:Description>Yahoo Search</os:Description>
<os:InputEncoding>UTF-8</os:InputEncoding>
<SuggestionURL>http://ff.search.yahoo.com/gossip?output=fxjson&amp;command=</SuggestionURL>
<os:Image width="16" height="16"></os:Image>
<os:Url type="text/html" method="GET" template="http://search.yahoo.com/search">
<os:Param name="p" value="{searchTerms}"/>