| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/autocomplete/keyword_provider.h" | 5 #include "chrome/browser/autocomplete/keyword_provider.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/string16.h" | 10 #include "base/string16.h" |
| (...skipping 301 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 312 | 312 |
| 313 if (remaining_start < input.length()) | 313 if (remaining_start < input.length()) |
| 314 remaining_input->assign(input.begin() + remaining_start, input.end()); | 314 remaining_input->assign(input.begin() + remaining_start, input.end()); |
| 315 | 315 |
| 316 // Return first token as keyword. | 316 // Return first token as keyword. |
| 317 return input.substr(0, first_white); | 317 return input.substr(0, first_white); |
| 318 } | 318 } |
| 319 | 319 |
| 320 // static | 320 // static |
| 321 void KeywordProvider::FillInURLAndContents( | 321 void KeywordProvider::FillInURLAndContents( |
| 322 Profile* profile, |
| 322 const string16& remaining_input, | 323 const string16& remaining_input, |
| 323 const TemplateURL* element, | 324 const TemplateURL* element, |
| 324 AutocompleteMatch* match) { | 325 AutocompleteMatch* match) { |
| 325 DCHECK(!element->short_name().empty()); | 326 DCHECK(!element->short_name().empty()); |
| 326 DCHECK(element->url()); | 327 DCHECK(element->url()); |
| 327 DCHECK(element->url()->IsValid()); | 328 DCHECK(element->url()->IsValid()); |
| 328 int message_id = element->IsExtensionKeyword() ? | 329 int message_id = element->IsExtensionKeyword() ? |
| 329 IDS_EXTENSION_KEYWORD_COMMAND : IDS_KEYWORD_SEARCH; | 330 IDS_EXTENSION_KEYWORD_COMMAND : IDS_KEYWORD_SEARCH; |
| 330 if (remaining_input.empty()) { | 331 if (remaining_input.empty()) { |
| 331 // Allow extension keyword providers to accept empty string input. This is | 332 // Allow extension keyword providers to accept empty string input. This is |
| (...skipping 15 matching lines...) Expand all Loading... |
| 347 AutocompleteMatch::ClassifyLocationInString(0, match->contents.length(), | 348 AutocompleteMatch::ClassifyLocationInString(0, match->contents.length(), |
| 348 match->contents.length(), ACMatchClassification::NONE, | 349 match->contents.length(), ACMatchClassification::NONE, |
| 349 &match->contents_class); | 350 &match->contents_class); |
| 350 } | 351 } |
| 351 } else { | 352 } else { |
| 352 // Create destination URL by escaping user input and substituting into | 353 // Create destination URL by escaping user input and substituting into |
| 353 // keyword template URL. The escaping here handles whitespace in user | 354 // keyword template URL. The escaping here handles whitespace in user |
| 354 // input, but we rely on later canonicalization functions to do more | 355 // input, but we rely on later canonicalization functions to do more |
| 355 // fixup to make the URL valid if necessary. | 356 // fixup to make the URL valid if necessary. |
| 356 DCHECK(element->url()->SupportsReplacement()); | 357 DCHECK(element->url()->SupportsReplacement()); |
| 357 match->destination_url = GURL(element->url()->ReplaceSearchTerms( | 358 match->destination_url = GURL(element->url()-> |
| 358 *element, remaining_input, | 359 ReplaceSearchTermsUsingProfile(profile, *element, remaining_input, |
| 359 TemplateURLRef::NO_SUGGESTIONS_AVAILABLE, string16())); | 360 TemplateURLRef::NO_SUGGESTIONS_AVAILABLE, string16())); |
| 360 std::vector<size_t> content_param_offsets; | 361 std::vector<size_t> content_param_offsets; |
| 361 match->contents.assign(l10n_util::GetStringFUTF16(message_id, | 362 match->contents.assign(l10n_util::GetStringFUTF16(message_id, |
| 362 element->short_name(), | 363 element->short_name(), |
| 363 remaining_input, | 364 remaining_input, |
| 364 &content_param_offsets)); | 365 &content_param_offsets)); |
| 365 if (content_param_offsets.size() == 2) { | 366 if (content_param_offsets.size() == 2) { |
| 366 AutocompleteMatch::ClassifyLocationInString(content_param_offsets[1], | 367 AutocompleteMatch::ClassifyLocationInString(content_param_offsets[1], |
| 367 remaining_input.length(), match->contents.length(), | 368 remaining_input.length(), match->contents.length(), |
| 368 ACMatchClassification::NONE, &match->contents_class); | 369 ACMatchClassification::NONE, &match->contents_class); |
| 369 } else { | 370 } else { |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 423 result.fill_into_edit.append(remaining_input); | 424 result.fill_into_edit.append(remaining_input); |
| 424 // If we wanted to set |result.inline_autocomplete_offset| correctly, we'd | 425 // If we wanted to set |result.inline_autocomplete_offset| correctly, we'd |
| 425 // need CleanUserInputKeyword() to return the amount of adjustment it's made | 426 // need CleanUserInputKeyword() to return the amount of adjustment it's made |
| 426 // to the user's input. Because right now inexact keyword matches can't score | 427 // to the user's input. Because right now inexact keyword matches can't score |
| 427 // more highly than a "what you typed" match from one of the other providers, | 428 // more highly than a "what you typed" match from one of the other providers, |
| 428 // we just don't bother to do this, and leave inline autocompletion off. | 429 // we just don't bother to do this, and leave inline autocompletion off. |
| 429 result.inline_autocomplete_offset = string16::npos; | 430 result.inline_autocomplete_offset = string16::npos; |
| 430 | 431 |
| 431 // Create destination URL and popup entry content by substituting user input | 432 // Create destination URL and popup entry content by substituting user input |
| 432 // into keyword templates. | 433 // into keyword templates. |
| 433 FillInURLAndContents(remaining_input, element, &result); | 434 FillInURLAndContents(profile_, remaining_input, element, &result); |
| 434 | 435 |
| 435 if (supports_replacement) | 436 if (supports_replacement) |
| 436 result.template_url = element; | 437 result.template_url = element; |
| 437 result.transition = PageTransition::KEYWORD; | 438 result.transition = PageTransition::KEYWORD; |
| 438 | 439 |
| 439 return result; | 440 return result; |
| 440 } | 441 } |
| 441 | 442 |
| 442 void KeywordProvider::Observe(int type, | 443 void KeywordProvider::Observe(int type, |
| 443 const NotificationSource& source, | 444 const NotificationSource& source, |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 530 } | 531 } |
| 531 | 532 |
| 532 void KeywordProvider::MaybeEndExtensionKeywordMode() { | 533 void KeywordProvider::MaybeEndExtensionKeywordMode() { |
| 533 if (!current_keyword_extension_id_.empty()) { | 534 if (!current_keyword_extension_id_.empty()) { |
| 534 ExtensionOmniboxEventRouter::OnInputCancelled( | 535 ExtensionOmniboxEventRouter::OnInputCancelled( |
| 535 profile_, current_keyword_extension_id_); | 536 profile_, current_keyword_extension_id_); |
| 536 | 537 |
| 537 current_keyword_extension_id_.clear(); | 538 current_keyword_extension_id_.clear(); |
| 538 } | 539 } |
| 539 } | 540 } |
| OLD | NEW |