Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(975)

Unified Diff: chrome/browser/search_engines/chrome_template_url_service_client.cc

Issue 651193002: Remove NOTIFICATION_HISTORY_URL_VISITED (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@373326.2
Patch Set: Rebase, address comments, fix tests and compilation Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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..0f51f26fb66b17fbbc536685c6a5a54d38e06dfd 100644
--- a/chrome/browser/search_engines/chrome_template_url_service_client.cc
+++ b/chrome/browser/search_engines/chrome_template_url_service_client.cc
@@ -4,34 +4,34 @@
#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) {
// 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() {
}
+void ChromeTemplateURLServiceClient::Shutdown() {
+ // ChromeTemplateURLServiceClient is owned by TemplateURLService which is a
+ // KeyedService with a dependency on HistoryService. Since it outlive the
Peter Kasting 2014/10/17 20:41:02 Nit: outlives This seems weird, though. If Templ
sdefresne 2014/10/18 17:31:47 You're right. I don't know why I though the opposi
+ // HistoryService, TemplateURLService will call Shutdown as part of the two
+ // steps shutdown of the KeyedService so that we can remove the observer
Peter Kasting 2014/10/17 20:41:02 Nit: two steps -> two-phase
sdefresne 2014/10/18 17:31:47 Acknowledged.
+ // before the Historyservice becomes invalid.
Peter Kasting 2014/10/17 20:41:03 Nit: the Historyservice -> |history_service_|
sdefresne 2014/10/18 17:31:47 Acknowledged.
+ if (history_service_)
+ history_service_->RemoveObserver(this);
+}
+
void ChromeTemplateURLServiceClient::SetOwner(TemplateURLService* owner) {
DCHECK(!owner_);
owner_ = owner;
@@ -39,30 +39,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 +71,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);
}

Powered by Google App Engine
This is Rietveld 408576698