Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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/renderer/searchbox/searchbox.h" | 5 #include "chrome/renderer/searchbox/searchbox.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
| 10 #include "base/strings/string_util.h" | 10 #include "base/strings/string_util.h" |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 #include "third_party/WebKit/public/web/WebDocument.h" | 21 #include "third_party/WebKit/public/web/WebDocument.h" |
| 22 #include "third_party/WebKit/public/web/WebFrame.h" | 22 #include "third_party/WebKit/public/web/WebFrame.h" |
| 23 #include "third_party/WebKit/public/web/WebView.h" | 23 #include "third_party/WebKit/public/web/WebView.h" |
| 24 #include "ui/base/resource/resource_bundle.h" | 24 #include "ui/base/resource/resource_bundle.h" |
| 25 | 25 |
| 26 namespace { | 26 namespace { |
| 27 | 27 |
| 28 // Size of the results cache. | 28 // Size of the results cache. |
| 29 const size_t kMaxInstantAutocompleteResultItemCacheSize = 100; | 29 const size_t kMaxInstantAutocompleteResultItemCacheSize = 100; |
| 30 | 30 |
| 31 // Returns true if items stored in |old_item_id_pairs| and |new_items| are | |
| 32 // equal. | |
| 33 bool AreMostVisitedItemsEqual( | |
| 34 std::vector<InstantMostVisitedItemIDPair> old_item_id_pairs, | |
|
samarth
2013/06/21 22:03:43
const reference, please
kmadhusu
2013/06/21 22:07:09
Done.
| |
| 35 const std::vector<InstantMostVisitedItem>& new_items) { | |
| 36 if (old_item_id_pairs.size() != new_items.size()) | |
| 37 return false; | |
| 38 | |
| 39 for (size_t i = 0; i < new_items.size(); ++i) { | |
| 40 if (new_items[i].url != old_item_id_pairs[i].second.url || | |
| 41 new_items[i].title != old_item_id_pairs[i].second.title) { | |
| 42 return false; | |
| 43 } | |
| 44 } | |
| 45 return true; | |
| 46 } | |
| 47 | |
| 31 } // namespace | 48 } // namespace |
| 32 | 49 |
| 33 namespace internal { // for testing | 50 namespace internal { // for testing |
| 34 | 51 |
| 35 // Parses |url| and fills in |id| with the InstantRestrictedID obtained from the | 52 // Parses |url| and fills in |id| with the InstantRestrictedID obtained from the |
| 36 // |url|. |render_view_id| is the ID of the associated RenderView. | 53 // |url|. |render_view_id| is the ID of the associated RenderView. |
| 37 // | 54 // |
| 38 // Valid |url| forms: | 55 // Valid |url| forms: |
| 39 // chrome-search://favicon/<view_id>/<restricted_id> | 56 // chrome-search://favicon/<view_id>/<restricted_id> |
| 40 // chrome-search://thumb/<view_id>/<restricted_id> | 57 // chrome-search://thumb/<view_id>/<restricted_id> |
| (...skipping 454 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 495 } | 512 } |
| 496 | 513 |
| 497 void SearchBox::SetQuery(const string16& query, bool verbatim) { | 514 void SearchBox::SetQuery(const string16& query, bool verbatim) { |
| 498 query_ = query; | 515 query_ = query; |
| 499 verbatim_ = verbatim; | 516 verbatim_ = verbatim; |
| 500 query_is_restricted_ = false; | 517 query_is_restricted_ = false; |
| 501 } | 518 } |
| 502 | 519 |
| 503 void SearchBox::OnMostVisitedChanged( | 520 void SearchBox::OnMostVisitedChanged( |
| 504 const std::vector<InstantMostVisitedItem>& items) { | 521 const std::vector<InstantMostVisitedItem>& items) { |
| 522 std::vector<InstantMostVisitedItemIDPair> last_known_items; | |
| 523 GetMostVisitedItems(&last_known_items); | |
| 524 | |
| 525 if (AreMostVisitedItemsEqual(last_known_items, items)) | |
| 526 return; // Do not send duplicate onmostvisitedchange events. | |
| 527 | |
| 505 most_visited_items_cache_.AddItems(items); | 528 most_visited_items_cache_.AddItems(items); |
| 506 if (render_view()->GetWebView() && render_view()->GetWebView()->mainFrame()) { | 529 if (render_view()->GetWebView() && render_view()->GetWebView()->mainFrame()) { |
| 507 extensions_v8::SearchBoxExtension::DispatchMostVisitedChanged( | 530 extensions_v8::SearchBoxExtension::DispatchMostVisitedChanged( |
| 508 render_view()->GetWebView()->mainFrame()); | 531 render_view()->GetWebView()->mainFrame()); |
| 509 } | 532 } |
| 510 } | 533 } |
| 511 | 534 |
| 512 void SearchBox::GetMostVisitedItems( | 535 void SearchBox::GetMostVisitedItems( |
| 513 std::vector<InstantMostVisitedItemIDPair>* items) const { | 536 std::vector<InstantMostVisitedItemIDPair>* items) const { |
| 514 return most_visited_items_cache_.GetCurrentItems(items); | 537 return most_visited_items_cache_.GetCurrentItems(items); |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 525 InstantMostVisitedItem item; | 548 InstantMostVisitedItem item; |
| 526 return GetMostVisitedItemWithID(item_id, &item) ? item.url : GURL(); | 549 return GetMostVisitedItemWithID(item_id, &item) ? item.url : GURL(); |
| 527 } | 550 } |
| 528 | 551 |
| 529 void SearchBox::OnToggleVoiceSearch() { | 552 void SearchBox::OnToggleVoiceSearch() { |
| 530 if (render_view()->GetWebView() && render_view()->GetWebView()->mainFrame()) { | 553 if (render_view()->GetWebView() && render_view()->GetWebView()->mainFrame()) { |
| 531 extensions_v8::SearchBoxExtension::DispatchToggleVoiceSearch( | 554 extensions_v8::SearchBoxExtension::DispatchToggleVoiceSearch( |
| 532 render_view()->GetWebView()->mainFrame()); | 555 render_view()->GetWebView()->mainFrame()); |
| 533 } | 556 } |
| 534 } | 557 } |
| OLD | NEW |