OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/ui/omnibox/alternate_nav_url_fetcher.h" | 5 #include "chrome/browser/ui/omnibox/alternate_nav_url_fetcher.h" |
6 | 6 |
7 #include "chrome/browser/infobars/infobar_service.h" | 7 #include "chrome/browser/infobars/infobar_service.h" |
8 #include "chrome/browser/intranet_redirect_detector.h" | 8 #include "chrome/browser/intranet_redirect_detector.h" |
9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
10 #include "chrome/browser/ui/omnibox/alternate_nav_infobar_delegate.h" | 10 #include "chrome/browser/ui/omnibox/alternate_nav_infobar_delegate.h" |
(...skipping 11 matching lines...) Expand all Loading... |
22 using content::NavigationController; | 22 using content::NavigationController; |
23 | 23 |
24 AlternateNavURLFetcher::AlternateNavURLFetcher( | 24 AlternateNavURLFetcher::AlternateNavURLFetcher( |
25 const GURL& alternate_nav_url) | 25 const GURL& alternate_nav_url) |
26 : alternate_nav_url_(alternate_nav_url), | 26 : alternate_nav_url_(alternate_nav_url), |
27 controller_(NULL), | 27 controller_(NULL), |
28 state_(NOT_STARTED), | 28 state_(NOT_STARTED), |
29 navigated_to_entry_(false) { | 29 navigated_to_entry_(false) { |
30 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_PENDING, | 30 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_PENDING, |
31 content::NotificationService::AllSources()); | 31 content::NotificationService::AllSources()); |
32 registrar_.Add(this, chrome::NOTIFICATION_INSTANT_COMMITTED, | |
33 content::NotificationService::AllSources()); | |
34 } | 32 } |
35 | 33 |
36 AlternateNavURLFetcher::~AlternateNavURLFetcher() { | 34 AlternateNavURLFetcher::~AlternateNavURLFetcher() { |
37 } | 35 } |
38 | 36 |
39 void AlternateNavURLFetcher::Observe( | 37 void AlternateNavURLFetcher::Observe( |
40 int type, | 38 int type, |
41 const content::NotificationSource& source, | 39 const content::NotificationSource& source, |
42 const content::NotificationDetails& details) { | 40 const content::NotificationDetails& details) { |
43 switch (type) { | 41 switch (type) { |
44 case content::NOTIFICATION_NAV_ENTRY_PENDING: { | 42 case content::NOTIFICATION_NAV_ENTRY_PENDING: { |
45 // If we've already received a notification for the same controller, we | 43 // If we've already received a notification for the same controller, we |
46 // should delete ourselves as that indicates that the page is being | 44 // should delete ourselves as that indicates that the page is being |
47 // re-loaded so this instance is now stale. | 45 // re-loaded so this instance is now stale. |
48 NavigationController* controller = | 46 NavigationController* controller = |
49 content::Source<NavigationController>(source).ptr(); | 47 content::Source<NavigationController>(source).ptr(); |
50 if (controller_ == controller) { | 48 if (controller_ == controller) { |
51 delete this; | 49 delete this; |
52 } else if (!controller_) { | 50 } else if (!controller_) { |
53 // Start listening for the commit notification. | 51 // Start listening for the commit notification. |
54 DCHECK(controller->GetPendingEntry()); | 52 DCHECK(controller->GetPendingEntry()); |
55 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED, | 53 registrar_.Add(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED, |
56 content::Source<NavigationController>( | 54 content::Source<NavigationController>( |
57 controller)); | 55 controller)); |
58 StartFetch(controller); | 56 StartFetch(controller); |
59 } | 57 } |
60 break; | 58 break; |
61 } | 59 } |
62 | 60 |
63 case chrome::NOTIFICATION_INSTANT_COMMITTED: { | |
64 // See above. | |
65 NavigationController* controller = | |
66 &content::Source<content::WebContents>(source)->GetController(); | |
67 if (controller_ == controller) { | |
68 delete this; | |
69 } else if (!controller_) { | |
70 navigated_to_entry_ = true; | |
71 StartFetch(controller); | |
72 } | |
73 break; | |
74 } | |
75 | |
76 case content::NOTIFICATION_NAV_ENTRY_COMMITTED: | 61 case content::NOTIFICATION_NAV_ENTRY_COMMITTED: |
77 // The page was navigated, we can show the infobar now if necessary. | 62 // The page was navigated, we can show the infobar now if necessary. |
78 registrar_.Remove(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED, | 63 registrar_.Remove(this, content::NOTIFICATION_NAV_ENTRY_COMMITTED, |
79 content::Source<NavigationController>(controller_)); | 64 content::Source<NavigationController>(controller_)); |
80 navigated_to_entry_ = true; | 65 navigated_to_entry_ = true; |
81 ShowInfobarIfPossible(); | 66 ShowInfobarIfPossible(); |
82 // WARNING: |this| may be deleted! | 67 // WARNING: |this| may be deleted! |
83 break; | 68 break; |
84 | 69 |
85 case content::NOTIFICATION_WEB_CONTENTS_DESTROYED: | 70 case content::NOTIFICATION_WEB_CONTENTS_DESTROYED: |
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
150 void AlternateNavURLFetcher::ShowInfobarIfPossible() { | 135 void AlternateNavURLFetcher::ShowInfobarIfPossible() { |
151 if (navigated_to_entry_ && (state_ == SUCCEEDED)) { | 136 if (navigated_to_entry_ && (state_ == SUCCEEDED)) { |
152 AlternateNavInfoBarDelegate::Create( | 137 AlternateNavInfoBarDelegate::Create( |
153 InfoBarService::FromWebContents(controller_->GetWebContents()), | 138 InfoBarService::FromWebContents(controller_->GetWebContents()), |
154 alternate_nav_url_); | 139 alternate_nav_url_); |
155 } else if (state_ != FAILED) { | 140 } else if (state_ != FAILED) { |
156 return; | 141 return; |
157 } | 142 } |
158 delete this; | 143 delete this; |
159 } | 144 } |
OLD | NEW |