Index: chrome/browser/search_engines/chrome_template_url_service_client.cc |
diff --git a/chrome/browser/search_engines/chrome_template_url_service_client.cc b/chrome/browser/search_engines/chrome_template_url_service_client.cc |
index a79f2fc7ef9ef84760946f47ccd4e4c90be3427d..0b129f2f7e914d7069fed515fc451ca1c2bad9fa 100644 |
--- a/chrome/browser/search_engines/chrome_template_url_service_client.cc |
+++ b/chrome/browser/search_engines/chrome_template_url_service_client.cc |
@@ -4,32 +4,25 @@ |
#include "chrome/browser/search_engines/chrome_template_url_service_client.h" |
-#include "chrome/browser/chrome_notification_types.h" |
-#include "chrome/browser/history/history_notifications.h" |
#include "chrome/browser/history/history_service.h" |
-#include "chrome/browser/history/history_service_factory.h" |
-#include "chrome/browser/profiles/profile.h" |
#include "components/search_engines/template_url_service.h" |
-#include "content/public/browser/notification_details.h" |
-#include "content/public/browser/notification_source.h" |
#include "extensions/common/constants.h" |
-ChromeTemplateURLServiceClient::ChromeTemplateURLServiceClient(Profile* profile) |
- : profile_(profile), |
- owner_(NULL) { |
- DCHECK(profile); |
- |
- // Register for notifications. |
+ChromeTemplateURLServiceClient::ChromeTemplateURLServiceClient( |
+ HistoryService* history_service) |
+ : owner_(NULL), history_service_(history_service) { |
+ // Register as HistoryServiceObserver. |
Peter Kasting
2014/10/14 16:40:53
Nit: This comment doesn't add anything to the code
sdefresne
2014/10/14 16:49:42
Done.
|
// TODO(sky): bug 1166191. The keywords should be moved into the history |
// db, which will mean we no longer need this notification and the history |
// backend can handle automatically adding the search terms as the user |
// navigates. |
- content::Source<Profile> profile_source(profile->GetOriginalProfile()); |
- notification_registrar_.Add(this, chrome::NOTIFICATION_HISTORY_URL_VISITED, |
- profile_source); |
+ if (history_service_) |
+ history_service_->AddObserver(this); |
} |
ChromeTemplateURLServiceClient::~ChromeTemplateURLServiceClient() { |
+ if (history_service_) |
+ history_service_->RemoveObserver(this); |
Peter Kasting
2014/10/14 16:40:53
This change adds a lifetime ordering requirement t
sdefresne
2014/10/14 16:49:42
Yes. ChromeTemplateURLServiceClient is owned by Te
Peter Kasting
2014/10/14 16:50:39
OK. I would not be opposed to a comment that expl
sdefresne
2014/10/17 14:32:38
My comment was correct but my analysis wasn't.
Ch
|
} |
void ChromeTemplateURLServiceClient::SetOwner(TemplateURLService* owner) { |
@@ -39,30 +32,24 @@ void ChromeTemplateURLServiceClient::SetOwner(TemplateURLService* owner) { |
void ChromeTemplateURLServiceClient::DeleteAllSearchTermsForKeyword( |
TemplateURLID id) { |
- HistoryService* history_service = |
- HistoryServiceFactory::GetForProfile(profile_, Profile::EXPLICIT_ACCESS); |
- if (history_service) |
- history_service->DeleteAllSearchTermsForKeyword(id); |
+ if (history_service_) |
+ history_service_->DeleteAllSearchTermsForKeyword(id); |
} |
void ChromeTemplateURLServiceClient::SetKeywordSearchTermsForURL( |
const GURL& url, |
TemplateURLID id, |
const base::string16& term) { |
- HistoryService* history_service = |
- HistoryServiceFactory::GetForProfile(profile_, Profile::EXPLICIT_ACCESS); |
- if (history_service) |
- history_service->SetKeywordSearchTermsForURL(url, id, term); |
+ if (history_service_) |
+ history_service_->SetKeywordSearchTermsForURL(url, id, term); |
} |
void ChromeTemplateURLServiceClient::AddKeywordGeneratedVisit(const GURL& url) { |
- HistoryService* history_service = |
- HistoryServiceFactory::GetForProfile(profile_, Profile::EXPLICIT_ACCESS); |
- if (history_service) |
- history_service->AddPage(url, base::Time::Now(), NULL, 0, GURL(), |
- history::RedirectList(), |
- ui::PAGE_TRANSITION_KEYWORD_GENERATED, |
- history::SOURCE_BROWSED, false); |
+ if (history_service_) |
+ history_service_->AddPage(url, base::Time::Now(), NULL, 0, GURL(), |
+ history::RedirectList(), |
+ ui::PAGE_TRANSITION_KEYWORD_GENERATED, |
+ history::SOURCE_BROWSED, false); |
} |
void ChromeTemplateURLServiceClient::RestoreExtensionInfoIfNecessary( |
@@ -77,20 +64,19 @@ void ChromeTemplateURLServiceClient::RestoreExtensionInfoIfNecessary( |
} |
} |
-void ChromeTemplateURLServiceClient::Observe( |
- int type, |
- const content::NotificationSource& source, |
- const content::NotificationDetails& details) { |
- DCHECK_EQ(type, chrome::NOTIFICATION_HISTORY_URL_VISITED); |
- |
+void ChromeTemplateURLServiceClient::OnURLVisited( |
+ HistoryService* history_service, |
+ ui::PageTransition transition, |
+ const history::URLRow& row, |
+ const history::RedirectList& redirects, |
+ base::Time visit_time) { |
+ DCHECK_EQ(history_service_, history_service); |
if (!owner_) |
return; |
- content::Details<history::URLVisitedDetails> history_details(details); |
TemplateURLService::URLVisitedDetails visited_details; |
- visited_details.url = history_details->row.url(); |
+ visited_details.url = row.url(); |
visited_details.is_keyword_transition = |
- ui::PageTransitionStripQualifier(history_details->transition) == |
- ui::PAGE_TRANSITION_KEYWORD; |
+ ui::PageTransitionCoreTypeIs(transition, ui::PAGE_TRANSITION_KEYWORD); |
owner_->OnHistoryURLVisited(visited_details); |
} |