OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/prerender/prerender_tab_helper.h" | 5 #include "chrome/browser/prerender/prerender_tab_helper.h" |
6 | 6 |
7 #include "base/metrics/histogram.h" | 7 #include "base/metrics/histogram.h" |
8 #include "base/string_number_conversions.h" | 8 #include "base/string_number_conversions.h" |
9 #include "base/time.h" | 9 #include "base/time.h" |
10 #include "chrome/browser/prerender/prerender_manager.h" | 10 #include "chrome/browser/prerender/prerender_manager.h" |
11 #include "chrome/browser/prerender/prerender_manager_factory.h" | 11 #include "chrome/browser/prerender/prerender_manager_factory.h" |
12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
| 13 #include "chrome/browser/ui/tab_contents/core_tab_helper.h" |
13 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" | 14 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" |
14 #include "content/browser/tab_contents/tab_contents.h" | 15 #include "content/browser/tab_contents/tab_contents.h" |
15 | 16 |
16 namespace prerender { | 17 namespace prerender { |
17 | 18 |
18 namespace { | 19 namespace { |
19 | 20 |
20 const int kMinHoverThresholdsMs[] = { | 21 const int kMinHoverThresholdsMs[] = { |
21 250 | 22 250 |
22 }; | 23 }; |
(...skipping 153 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
176 PrerenderTabHelper::~PrerenderTabHelper() { | 177 PrerenderTabHelper::~PrerenderTabHelper() { |
177 } | 178 } |
178 | 179 |
179 void PrerenderTabHelper::ProvisionalChangeToMainFrameUrl( | 180 void PrerenderTabHelper::ProvisionalChangeToMainFrameUrl( |
180 const GURL& url, | 181 const GURL& url, |
181 const GURL& opener_url) { | 182 const GURL& opener_url) { |
182 url_ = url; | 183 url_ = url; |
183 RecordPageviewEvent(PAGEVIEW_EVENT_NEW_URL); | 184 RecordPageviewEvent(PAGEVIEW_EVENT_NEW_URL); |
184 if (IsTopSite(url)) | 185 if (IsTopSite(url)) |
185 RecordPageviewEvent(PAGEVIEW_EVENT_TOP_SITE_NEW_URL); | 186 RecordPageviewEvent(PAGEVIEW_EVENT_TOP_SITE_NEW_URL); |
186 if (!tab_->delegate()) | 187 if (!tab_->core_tab_helper()->delegate()) |
187 return; // PrerenderManager needs a delegate to handle the swap. | 188 return; // PrerenderManager needs a delegate to handle the swap. |
188 PrerenderManager* prerender_manager = MaybeGetPrerenderManager(); | 189 PrerenderManager* prerender_manager = MaybeGetPrerenderManager(); |
189 if (!prerender_manager) | 190 if (!prerender_manager) |
190 return; | 191 return; |
191 if (prerender_manager->IsTabContentsPrerendering(tab_contents())) | 192 if (prerender_manager->IsTabContentsPrerendering(tab_contents())) |
192 return; | 193 return; |
193 prerender_manager->MarkTabContentsAsNotPrerendered(tab_contents()); | 194 prerender_manager->MarkTabContentsAsNotPrerendered(tab_contents()); |
194 MaybeUsePrerenderedPage(url, opener_url); | 195 MaybeUsePrerenderedPage(url, opener_url); |
195 } | 196 } |
196 | 197 |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
301 | 302 |
302 current_hover_url_ = GURL(); | 303 current_hover_url_ = GURL(); |
303 } | 304 } |
304 | 305 |
305 bool PrerenderTabHelper::IsTopSite(const GURL& url) { | 306 bool PrerenderTabHelper::IsTopSite(const GURL& url) { |
306 PrerenderManager* pm = MaybeGetPrerenderManager(); | 307 PrerenderManager* pm = MaybeGetPrerenderManager(); |
307 return (pm && pm->IsTopSite(url)); | 308 return (pm && pm->IsTopSite(url)); |
308 } | 309 } |
309 | 310 |
310 } // namespace prerender | 311 } // namespace prerender |
OLD | NEW |