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/prerender/prerender_tab_helper.h" | 5 #include "chrome/browser/prerender/prerender_tab_helper.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
9 #include "base/time/time.h" | 9 #include "base/time/time.h" |
10 #include "chrome/browser/prerender/prerender_histograms.h" | 10 #include "chrome/browser/prerender/prerender_histograms.h" |
11 #include "chrome/browser/prerender/prerender_local_predictor.h" | 11 #include "chrome/browser/prerender/prerender_local_predictor.h" |
12 #include "chrome/browser/prerender/prerender_manager.h" | 12 #include "chrome/browser/prerender/prerender_manager.h" |
13 #include "chrome/browser/prerender/prerender_manager_factory.h" | 13 #include "chrome/browser/prerender/prerender_manager_factory.h" |
14 #include "chrome/browser/profiles/profile.h" | 14 #include "chrome/browser/profiles/profile.h" |
15 #include "components/password_manager/core/browser/password_manager.h" | 15 #include "components/password_manager/core/browser/password_manager.h" |
16 #include "content/public/browser/navigation_details.h" | 16 #include "content/public/browser/navigation_details.h" |
17 #include "content/public/browser/navigation_entry.h" | 17 #include "content/public/browser/navigation_entry.h" |
18 #include "content/public/browser/render_frame_host.h" | 18 #include "content/public/browser/render_frame_host.h" |
| 19 #include "content/public/browser/resource_request_details.h" |
19 #include "content/public/browser/web_contents.h" | 20 #include "content/public/browser/web_contents.h" |
20 #include "content/public/common/frame_navigate_params.h" | 21 #include "content/public/common/frame_navigate_params.h" |
21 | 22 |
22 using content::WebContents; | 23 using content::WebContents; |
23 | 24 |
24 DEFINE_WEB_CONTENTS_USER_DATA_KEY(prerender::PrerenderTabHelper); | 25 DEFINE_WEB_CONTENTS_USER_DATA_KEY(prerender::PrerenderTabHelper); |
25 | 26 |
26 namespace prerender { | 27 namespace prerender { |
27 | 28 |
28 namespace { | 29 namespace { |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
74 prerender_manager->IsWebContentsPrerendering(web_contents, &origin_)) { | 75 prerender_manager->IsWebContentsPrerendering(web_contents, &origin_)) { |
75 navigation_type_ = NAVIGATION_TYPE_PRERENDERED; | 76 navigation_type_ = NAVIGATION_TYPE_PRERENDERED; |
76 } else { | 77 } else { |
77 navigation_type_ = NAVIGATION_TYPE_NORMAL; | 78 navigation_type_ = NAVIGATION_TYPE_NORMAL; |
78 } | 79 } |
79 } | 80 } |
80 | 81 |
81 PrerenderTabHelper::~PrerenderTabHelper() { | 82 PrerenderTabHelper::~PrerenderTabHelper() { |
82 } | 83 } |
83 | 84 |
84 void PrerenderTabHelper::ProvisionalChangeToMainFrameUrl( | 85 void PrerenderTabHelper::DidGetRedirectForResourceRequest( |
85 const GURL& url, | 86 content::RenderViewHost* render_view_host, |
86 content::RenderFrameHost* render_frame_host) { | 87 const content::ResourceRedirectDetails& details) { |
87 url_ = url; | 88 if (details.resource_type != content::RESOURCE_TYPE_MAIN_FRAME) |
| 89 return; |
| 90 |
| 91 url_ = details.new_url; |
88 RecordEvent(EVENT_MAINFRAME_CHANGE); | 92 RecordEvent(EVENT_MAINFRAME_CHANGE); |
89 RecordEventIfLoggedInURL(EVENT_MAINFRAME_CHANGE_DOMAIN_LOGGED_IN, url); | 93 RecordEventIfLoggedInURL(EVENT_MAINFRAME_CHANGE_DOMAIN_LOGGED_IN, url_); |
90 PrerenderManager* prerender_manager = MaybeGetPrerenderManager(); | 94 PrerenderManager* prerender_manager = MaybeGetPrerenderManager(); |
91 if (!prerender_manager) | 95 if (!prerender_manager) |
92 return; | 96 return; |
93 if (prerender_manager->IsWebContentsPrerendering(web_contents(), NULL)) | 97 if (prerender_manager->IsWebContentsPrerendering(web_contents(), NULL)) |
94 return; | 98 return; |
95 ReportTabHelperURLSeenToLocalPredictor(prerender_manager, url, | 99 ReportTabHelperURLSeenToLocalPredictor(prerender_manager, url_, |
96 web_contents()); | 100 web_contents()); |
97 } | 101 } |
98 | 102 |
99 void PrerenderTabHelper::DidCommitProvisionalLoadForFrame( | 103 void PrerenderTabHelper::DidCommitProvisionalLoadForFrame( |
100 content::RenderFrameHost* render_frame_host, | 104 content::RenderFrameHost* render_frame_host, |
101 const GURL& validated_url, | 105 const GURL& validated_url, |
102 content::PageTransition transition_type) { | 106 content::PageTransition transition_type) { |
103 if (render_frame_host->GetParent()) | 107 if (render_frame_host->GetParent()) |
104 return; | 108 return; |
105 RecordEvent(EVENT_MAINFRAME_COMMIT); | 109 RecordEvent(EVENT_MAINFRAME_COMMIT); |
(...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
267 prerender_manager->RecordPerceivedPageLoadTime( | 271 prerender_manager->RecordPerceivedPageLoadTime( |
268 origin_, navigation_type_, perceived_page_load_time, | 272 origin_, navigation_type_, perceived_page_load_time, |
269 fraction_plt_elapsed_at_swap_in, url_); | 273 fraction_plt_elapsed_at_swap_in, url_); |
270 | 274 |
271 // Reset state for the next navigation. | 275 // Reset state for the next navigation. |
272 navigation_type_ = NAVIGATION_TYPE_NORMAL; | 276 navigation_type_ = NAVIGATION_TYPE_NORMAL; |
273 origin_ = ORIGIN_NONE; | 277 origin_ = ORIGIN_NONE; |
274 } | 278 } |
275 | 279 |
276 } // namespace prerender | 280 } // namespace prerender |
OLD | NEW |