mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 720598 - nsAutocompleteController HandleKeyNavigation() and EnterMatch() call GetDefaultCompleteValue() with a bogus aResultIndex.
r=gavin
This commit is contained in:
parent
26d4f75f0c
commit
fcf0dbceda
@ -524,7 +524,7 @@ nsAutoCompleteController::HandleKeyNavigation(PRUint32 aKey, bool *_retval)
|
||||
nsAutoString value;
|
||||
nsAutoString inputValue;
|
||||
input->GetTextValue(inputValue);
|
||||
if (NS_SUCCEEDED(GetDefaultCompleteValue(selectedIndex, false, value)) &&
|
||||
if (NS_SUCCEEDED(GetDefaultCompleteValue(-1, false, value)) &&
|
||||
value.Equals(inputValue, nsCaseInsensitiveStringComparator())) {
|
||||
input->SetTextValue(value);
|
||||
input->SelectTextRange(value.Length(), value.Length());
|
||||
@ -1162,7 +1162,7 @@ nsAutoCompleteController::EnterMatch(bool aIsPopupSelection)
|
||||
nsAutoString defaultIndexValue;
|
||||
nsAutoString inputValue;
|
||||
input->GetTextValue(inputValue);
|
||||
if (NS_SUCCEEDED(GetDefaultCompleteValue(selectedIndex, false, defaultIndexValue)) &&
|
||||
if (NS_SUCCEEDED(GetDefaultCompleteValue(-1, false, defaultIndexValue)) &&
|
||||
defaultIndexValue.Equals(inputValue, nsCaseInsensitiveStringComparator()))
|
||||
value = defaultIndexValue;
|
||||
}
|
||||
|
@ -0,0 +1,63 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
function AutoCompleteResult(aValues) {
|
||||
this._values = aValues;
|
||||
this.defaultIndex = 0;
|
||||
}
|
||||
AutoCompleteResult.prototype = Object.create(AutoCompleteResultBase.prototype);
|
||||
|
||||
function AutoCompleteInput(aSearches) {
|
||||
this.searches = aSearches;
|
||||
this.popup.selectedIndex = -1;
|
||||
this.completeDefaultIndex = true;
|
||||
}
|
||||
AutoCompleteInput.prototype = Object.create(AutoCompleteInputBase.prototype);
|
||||
|
||||
function run_test() {
|
||||
run_next_test();
|
||||
}
|
||||
|
||||
add_test(function test_keyNavigation() {
|
||||
doSearch("MOZ", "mozilla", function(aController) {
|
||||
do_check_eq(aController.input.textValue, "MOZilla");
|
||||
aController.handleKeyNavigation(Ci.nsIDOMKeyEvent.DOM_VK_RIGHT);
|
||||
do_check_eq(aController.input.textValue, "mozilla");
|
||||
});
|
||||
});
|
||||
|
||||
add_test(function test_handleEnter() {
|
||||
doSearch("MOZ", "mozilla", function(aController) {
|
||||
do_check_eq(aController.input.textValue, "MOZilla");
|
||||
aController.handleEnter(false);
|
||||
do_check_eq(aController.input.textValue, "mozilla");
|
||||
});
|
||||
});
|
||||
|
||||
function doSearch(aSearchString, aResultValue, aOnCompleteCallback) {
|
||||
let search = new AutoCompleteSearchBase("search",
|
||||
new AutoCompleteResult([ "mozilla", "toolkit" ], 0));
|
||||
registerAutoCompleteSearch(search);
|
||||
|
||||
let controller = Cc["@mozilla.org/autocomplete/controller;1"].
|
||||
getService(Ci.nsIAutoCompleteController);
|
||||
|
||||
// Make an AutoCompleteInput that uses our searches and confirms results.
|
||||
let input = new AutoCompleteInput([ search.name ]);
|
||||
input.textValue = aSearchString;
|
||||
|
||||
// Caret must be at the end for autofill to happen.
|
||||
let strLen = aSearchString.length;
|
||||
input.selectTextRange(strLen, strLen);
|
||||
controller.input = input;
|
||||
controller.startSearch(aSearchString);
|
||||
|
||||
input.onSearchComplete = function onSearchComplete() {
|
||||
aOnCompleteCallback(controller);
|
||||
|
||||
// Clean up.
|
||||
unregisterAutoCompleteSearch(search);
|
||||
run_next_test();
|
||||
};
|
||||
}
|
@ -10,6 +10,7 @@ tail =
|
||||
[test_660156.js]
|
||||
[test_autocomplete_multiple.js]
|
||||
[test_badDefaultIndex.js]
|
||||
[test_completeDefaultIndex_casing.js]
|
||||
[test_hiddenResult.js]
|
||||
[test_previousResult.js]
|
||||
[test_stopSearch.js]
|
||||
|
Loading…
Reference in New Issue
Block a user