diff options
author | pkasting@chromium.org <pkasting@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-22 01:47:16 +0000 |
---|---|---|
committer | pkasting@chromium.org <pkasting@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-22 01:47:16 +0000 |
commit | b3edb31e6ec0a3a3a312718933e907f341606548 (patch) | |
tree | b9e73b4dd19be2535b13c1ab2b270d84dafbd910 | |
parent | 825ff8d48aee34b10ef6198743755b88c01a0e6b (diff) | |
download | chromium_src-b3edb31e6ec0a3a3a312718933e907f341606548.zip chromium_src-b3edb31e6ec0a3a3a312718933e907f341606548.tar.gz chromium_src-b3edb31e6ec0a3a3a312718933e907f341606548.tar.bz2 |
More NotificationRegistrar conversions.
BUG=2381
Review URL: http://codereview.chromium.org/115674
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@16699 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/browsing_data_remover.cc | 16 | ||||
-rw-r--r-- | chrome/browser/browsing_data_remover.h | 9 | ||||
-rw-r--r-- | chrome/browser/google_url_tracker.cc | 8 | ||||
-rw-r--r-- | chrome/browser/google_url_tracker.h | 3 |
4 files changed, 11 insertions, 25 deletions
diff --git a/chrome/browser/browsing_data_remover.cc b/chrome/browser/browsing_data_remover.cc index 0929238..5b3bc70 100644 --- a/chrome/browser/browsing_data_remover.cc +++ b/chrome/browser/browsing_data_remover.cc @@ -40,7 +40,6 @@ BrowsingDataRemover::BrowsingDataRemover(Profile* profile, : profile_(profile), delete_begin_(delete_begin), delete_end_(delete_end), - waiting_for_keywords_(false), waiting_for_clear_history_(false), waiting_for_clear_cache_(false) { DCHECK(profile); @@ -80,10 +79,8 @@ void BrowsingDataRemover::Remove(int remove_mask) { // As part of history deletion we also delete the auto-generated keywords. TemplateURLModel* keywords_model = profile_->GetTemplateURLModel(); if (keywords_model && !keywords_model->loaded()) { - waiting_for_keywords_ = true; - NotificationService::current()->AddObserver( - this, NotificationType::TEMPLATE_URL_MODEL_LOADED, - Source<TemplateURLModel>(keywords_model)); + registrar_.Add(this, NotificationType::TEMPLATE_URL_MODEL_LOADED, + Source<TemplateURLModel>(keywords_model)); keywords_model->Load(); } else if (keywords_model) { keywords_model->RemoveAutoGeneratedBetween(delete_begin_, delete_end_); @@ -198,15 +195,8 @@ void BrowsingDataRemover::Observe(NotificationType type, DCHECK(type == NotificationType::TEMPLATE_URL_MODEL_LOADED); TemplateURLModel* model = Source<TemplateURLModel>(source).ptr(); if (model->profile() == profile_->GetOriginalProfile()) { - NotificationService::current()->RemoveObserver( - this, - NotificationType::TEMPLATE_URL_MODEL_LOADED, - Source<TemplateURLModel>(model)); - + registrar_.RemoveAll(); model->RemoveAutoGeneratedBetween(delete_begin_, delete_end_); - - waiting_for_keywords_ = false; - NotifyAndDeleteIfDone(); } } diff --git a/chrome/browser/browsing_data_remover.h b/chrome/browser/browsing_data_remover.h index 62172a0..0425c6f 100644 --- a/chrome/browser/browsing_data_remover.h +++ b/chrome/browser/browsing_data_remover.h @@ -8,7 +8,7 @@ #include "base/observer_list.h" #include "base/time.h" #include "chrome/browser/cancelable_request.h" -#include "chrome/common/notification_observer.h" +#include "chrome/common/notification_registrar.h" class MessageLoop; class Profile; @@ -90,10 +90,12 @@ class BrowsingDataRemover : public NotificationObserver { // Returns true if we're all done. bool all_done() { - return !waiting_for_keywords_ && !waiting_for_clear_cache_ && + return registrar_.IsEmpty() && !waiting_for_clear_cache_ && !waiting_for_clear_history_; } + NotificationRegistrar registrar_; + // Profile we're to remove from. Profile* profile_; @@ -106,9 +108,6 @@ class BrowsingDataRemover : public NotificationObserver { // True if Remove has been invoked. static bool removing_; - // True if we're waiting for the TemplateURLModel to finish loading. - bool waiting_for_keywords_; - // True if we're waiting for the history to be deleted. bool waiting_for_clear_history_; diff --git a/chrome/browser/google_url_tracker.cc b/chrome/browser/google_url_tracker.cc index 2e26147..8b60ae4 100644 --- a/chrome/browser/google_url_tracker.cc +++ b/chrome/browser/google_url_tracker.cc @@ -25,9 +25,8 @@ GoogleURLTracker::GoogleURLTracker() already_fetched_(false), need_to_fetch_(false), request_context_available_(!!Profile::GetDefaultRequestContext()) { - NotificationService::current()->AddObserver(this, - NotificationType::DEFAULT_REQUEST_CONTEXT_AVAILABLE, - NotificationService::AllSources()); + registrar_.Add(this, NotificationType::DEFAULT_REQUEST_CONTEXT_AVAILABLE, + NotificationService::AllSources()); // Because this function can be called during startup, when kicking off a URL // fetch can eat up 20 ms of time, we delay five seconds, which is hopefully @@ -42,9 +41,6 @@ GoogleURLTracker::GoogleURLTracker() } GoogleURLTracker::~GoogleURLTracker() { - NotificationService::current()->RemoveObserver(this, - NotificationType::DEFAULT_REQUEST_CONTEXT_AVAILABLE, - NotificationService::AllSources()); } // static diff --git a/chrome/browser/google_url_tracker.h b/chrome/browser/google_url_tracker.h index bdc7290..987987d 100644 --- a/chrome/browser/google_url_tracker.h +++ b/chrome/browser/google_url_tracker.h @@ -8,7 +8,7 @@ #include <string> #include "chrome/browser/net/url_fetcher.h" -#include "chrome/common/notification_observer.h" +#include "chrome/common/notification_registrar.h" #include "googleurl/src/gurl.h" #include "testing/gtest/include/gtest/gtest_prod.h" @@ -90,6 +90,7 @@ class GoogleURLTracker : public URLFetcher::Delegate, static const char kDefaultGoogleHomepage[]; + NotificationRegistrar registrar_; GURL google_url_; ScopedRunnableMethodFactory<GoogleURLTracker> fetcher_factory_; scoped_ptr<URLFetcher> fetcher_; |