OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/search/instant_service.h" | 5 #include "chrome/browser/search/instant_service.h" |
6 | 6 |
7 #include "chrome/browser/chrome_notification_types.h" | 7 #include "chrome/browser/chrome_notification_types.h" |
8 #include "chrome/browser/history/top_sites_factory.h" | 8 #include "chrome/browser/history/top_sites_factory.h" |
9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
10 #include "chrome/browser/search/instant_io_context.h" | 10 #include "chrome/browser/search/instant_io_context.h" |
(...skipping 389 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
400 UIThreadSearchTermsData(profile_)); | 400 UIThreadSearchTermsData(profile_)); |
401 if (default_search_provider_changed) { | 401 if (default_search_provider_changed) { |
402 previous_default_search_provider_.reset( | 402 previous_default_search_provider_.reset( |
403 template_url ? new TemplateURLData(template_url->data()) : NULL); | 403 template_url ? new TemplateURLData(template_url->data()) : NULL); |
404 } | 404 } |
405 | 405 |
406 // Note that, even if the TemplateURL for the Default Search Provider has not | 406 // Note that, even if the TemplateURL for the Default Search Provider has not |
407 // changed, the effective URLs might change if they reference the Google base | 407 // changed, the effective URLs might change if they reference the Google base |
408 // URL. The TemplateURLService will notify us when the effective URL changes | 408 // URL. The TemplateURLService will notify us when the effective URL changes |
409 // in this way but it's up to us to do the work to check both. | 409 // in this way but it's up to us to do the work to check both. |
| 410 bool google_base_url_domain_changed = false; |
410 GURL google_base_url(UIThreadSearchTermsData(profile_).GoogleBaseURLValue()); | 411 GURL google_base_url(UIThreadSearchTermsData(profile_).GoogleBaseURLValue()); |
411 if (google_base_url != previous_google_base_url_) { | 412 if (google_base_url != previous_google_base_url_) { |
412 previous_google_base_url_ = google_base_url; | 413 previous_google_base_url_ = google_base_url; |
413 if (template_url && template_url->HasGoogleBaseURLs( | 414 if (template_url && template_url->HasGoogleBaseURLs( |
414 UIThreadSearchTermsData(profile_))) | 415 UIThreadSearchTermsData(profile_))) |
415 default_search_provider_changed = true; | 416 google_base_url_domain_changed = true; |
416 } | 417 } |
417 | 418 |
418 if (default_search_provider_changed) { | 419 if (default_search_provider_changed || google_base_url_domain_changed) { |
419 ResetInstantSearchPrerenderer(); | 420 ResetInstantSearchPrerenderer(); |
420 FOR_EACH_OBSERVER(InstantServiceObserver, observers_, | 421 FOR_EACH_OBSERVER( |
421 DefaultSearchProviderChanged()); | 422 InstantServiceObserver, observers_, |
| 423 DefaultSearchProviderChanged(google_base_url_domain_changed)); |
422 } | 424 } |
423 } | 425 } |
424 | 426 |
425 void InstantService::TopSitesLoaded(history::TopSites* top_sites) { | 427 void InstantService::TopSitesLoaded(history::TopSites* top_sites) { |
426 } | 428 } |
427 | 429 |
428 void InstantService::TopSitesChanged(history::TopSites* top_sites) { | 430 void InstantService::TopSitesChanged(history::TopSites* top_sites) { |
429 top_sites->GetMostVisitedURLs( | 431 top_sites->GetMostVisitedURLs( |
430 base::Bind(&InstantService::OnMostVisitedItemsReceived, | 432 base::Bind(&InstantService::OnMostVisitedItemsReceived, |
431 weak_ptr_factory_.GetWeakPtr()), | 433 weak_ptr_factory_.GetWeakPtr()), |
432 false); | 434 false); |
433 } | 435 } |
434 | 436 |
435 void InstantService::ResetInstantSearchPrerenderer() { | 437 void InstantService::ResetInstantSearchPrerenderer() { |
436 if (!chrome::ShouldPrefetchSearchResults()) | 438 if (!chrome::ShouldPrefetchSearchResults()) |
437 return; | 439 return; |
438 | 440 |
439 GURL url(chrome::GetSearchResultPrefetchBaseURL(profile_)); | 441 GURL url(chrome::GetSearchResultPrefetchBaseURL(profile_)); |
440 instant_prerenderer_.reset( | 442 instant_prerenderer_.reset( |
441 url.is_valid() ? new InstantSearchPrerenderer(profile_, url) : NULL); | 443 url.is_valid() ? new InstantSearchPrerenderer(profile_, url) : NULL); |
442 } | 444 } |
OLD | NEW |