summaryrefslogtreecommitdiffstats
path: root/chrome/browser/alternate_nav_url_fetcher.cc
diff options
context:
space:
mode:
authorbrettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-16 20:16:08 +0000
committerbrettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-16 20:16:08 +0000
commitd778c4701b5e5ffec54eee51d2427836f4f5c0b1 (patch)
tree850ae017300e5a83d4a4775451051ffc2c9187bd /chrome/browser/alternate_nav_url_fetcher.cc
parent90e2b34d20d3cf5662ea8776580b9e437b4698a8 (diff)
downloadchromium_src-d778c4701b5e5ffec54eee51d2427836f4f5c0b1.zip
chromium_src-d778c4701b5e5ffec54eee51d2427836f4f5c0b1.tar.gz
chromium_src-d778c4701b5e5ffec54eee51d2427836f4f5c0b1.tar.bz2
Remove an explicit call from the NavigationController to the alternate URL
fetcher since there is already a notification that does this. I created a class that will automatically unregister for notifications when it goes out of scope and used it here. I think it will be useful for most consumers of notifications. Review URL: http://codereview.chromium.org/2895 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2276 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/alternate_nav_url_fetcher.cc')
-rw-r--r--chrome/browser/alternate_nav_url_fetcher.cc76
1 files changed, 42 insertions, 34 deletions
diff --git a/chrome/browser/alternate_nav_url_fetcher.cc b/chrome/browser/alternate_nav_url_fetcher.cc
index fef750e..3f16e2f 100644
--- a/chrome/browser/alternate_nav_url_fetcher.cc
+++ b/chrome/browser/alternate_nav_url_fetcher.cc
@@ -11,47 +11,53 @@
AlternateNavURLFetcher::AlternateNavURLFetcher(
const std::wstring& alternate_nav_url)
- : alternate_nav_url_(alternate_nav_url),
- controller_(NULL),
- state_(NOT_STARTED),
- navigated_to_entry_(false) {
- NotificationService::current()->AddObserver(this,
- NOTIFY_NAV_ENTRY_PENDING, NotificationService::AllSources());
+ : alternate_nav_url_(alternate_nav_url),
+ controller_(NULL),
+ state_(NOT_STARTED),
+ navigated_to_entry_(false) {
+ registrar_.Add(this, NOTIFY_NAV_ENTRY_PENDING,
+ NotificationService::AllSources());
}
AlternateNavURLFetcher::~AlternateNavURLFetcher() {
- if (state_ == NOT_STARTED) {
- // Never caught the NavigationController notification.
- NotificationService::current()->RemoveObserver(this,
- NOTIFY_NAV_ENTRY_PENDING, NotificationService::AllSources());
- } // Otherwise, Observe() removed the observer already.
-}
-
-void AlternateNavURLFetcher::OnNavigatedToEntry() {
- if (navigated_to_entry_)
- return;
- navigated_to_entry_ = true;
- if (state_ == SUCCEEDED)
- ShowInfobar();
}
void AlternateNavURLFetcher::Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details) {
- controller_ = Source<NavigationController>(source).ptr();
- if (!controller_->GetPendingEntry())
- return; // No entry to attach ourselves to.
- controller_->SetAlternateNavURLFetcher(this);
+ switch (type) {
+ case NOTIFY_NAV_ENTRY_PENDING:
+ controller_ = Source<NavigationController>(source).ptr();
+ if (!controller_->GetPendingEntry())
+ return; // No entry to attach ourselves to.
+ controller_->SetAlternateNavURLFetcher(this);
+
+ // Unregister for this notification now that we're pending, and start
+ // listening for the corresponding commit.
+ registrar_.Remove(this, NOTIFY_NAV_ENTRY_PENDING,
+ NotificationService::AllSources());
+ registrar_.Add(this, NOTIFY_NAV_ENTRY_COMMITTED,
+ Source<NavigationController>(controller_));
- NotificationService::current()->RemoveObserver(this,
- NOTIFY_NAV_ENTRY_PENDING, NotificationService::AllSources());
+ DCHECK_EQ(NOT_STARTED, state_);
+ state_ = IN_PROGRESS;
+ fetcher_.reset(new URLFetcher(GURL(alternate_nav_url_), URLFetcher::HEAD,
+ this));
+ fetcher_->set_request_context(controller_->profile()->GetRequestContext());
+ fetcher_->Start();
+ break;
- DCHECK_EQ(NOT_STARTED, state_);
- state_ = IN_PROGRESS;
- fetcher_.reset(new URLFetcher(GURL(alternate_nav_url_), URLFetcher::HEAD,
- this));
- fetcher_->set_request_context(controller_->profile()->GetRequestContext());
- fetcher_->Start();
+ case NOTIFY_NAV_ENTRY_COMMITTED:
+ // The page was navigated, we can show the infobar now if necessary.
+ registrar_.Remove(this, NOTIFY_NAV_ENTRY_COMMITTED,
+ Source<NavigationController>(controller_));
+ navigated_to_entry_ = true;
+ ShowInfobarIfPossible();
+ break;
+
+ default:
+ NOTREACHED();
+ }
}
void AlternateNavURLFetcher::OnURLFetchComplete(const URLFetcher* source,
@@ -66,14 +72,16 @@ void AlternateNavURLFetcher::OnURLFetchComplete(const URLFetcher* source,
(((response_code / 100) == 2) ||
(response_code == 401) || (response_code == 407))) {
state_ = SUCCEEDED;
- if (navigated_to_entry_)
- ShowInfobar();
+ ShowInfobarIfPossible();
} else {
state_ = FAILED;
}
}
-void AlternateNavURLFetcher::ShowInfobar() {
+void AlternateNavURLFetcher::ShowInfobarIfPossible() {
+ if (!navigated_to_entry_ || state_ != SUCCEEDED)
+ return;
+
const NavigationEntry* const entry = controller_->GetActiveEntry();
DCHECK(entry);
if (entry->tab_type() != TAB_CONTENTS_WEB)