Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(150)

Side by Side Diff: chrome/renderer/prerender/prerender_helper.cc

Issue 2411863002: [NoStatePrefetch] Kill renderer after preload scanning (Closed)
Patch Set: Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/renderer/prerender/prerender_helper.h" 5 #include "chrome/renderer/prerender/prerender_helper.h"
6 6
7 #include "base/metrics/field_trial.h" 7 #include "base/metrics/field_trial.h"
8 #include "base/metrics/histogram.h" 8 #include "base/metrics/histogram.h"
9 #include "chrome/common/prerender_messages.h" 9 #include "chrome/common/prerender_messages.h"
10 #include "content/common/view_messages.h"
10 #include "content/public/renderer/document_state.h" 11 #include "content/public/renderer/document_state.h"
11 #include "content/public/renderer/render_frame.h" 12 #include "content/public/renderer/render_frame.h"
12 #include "content/public/renderer/render_view.h" 13 #include "content/public/renderer/render_view.h"
13 #include "third_party/WebKit/public/web/WebFrame.h" 14 #include "third_party/WebKit/public/web/WebFrame.h"
14 #include "third_party/WebKit/public/web/WebView.h" 15 #include "third_party/WebKit/public/web/WebView.h"
15 16
16 using content::DocumentState; 17 using content::DocumentState;
17 18
18 namespace { 19 namespace {
19 20
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
62 PrerenderMode PrerenderHelper::GetPrerenderMode( 63 PrerenderMode PrerenderHelper::GetPrerenderMode(
63 const content::RenderFrame* render_frame) { 64 const content::RenderFrame* render_frame) {
64 PrerenderHelper* helper = PrerenderHelper::Get(render_frame); 65 PrerenderHelper* helper = PrerenderHelper::Get(render_frame);
65 if (!helper) 66 if (!helper)
66 return NO_PRERENDER; 67 return NO_PRERENDER;
67 68
68 DCHECK_NE(helper->prerender_mode_, NO_PRERENDER); 69 DCHECK_NE(helper->prerender_mode_, NO_PRERENDER);
69 return helper->prerender_mode_; 70 return helper->prerender_mode_;
70 } 71 }
71 72
73 // static
74 void PrerenderHelper::SendPrefetchFinished(content::RenderFrame* render_frame) {
clamy 2016/10/12 11:19:57 A few things here: 1) It's weird to use a ViewHos
pasko 2016/10/12 13:59:40 Thanks!
mattcary 2016/10/12 14:09:17 Silly question: is the render_process_id_ that the
clamy 2016/10/12 14:16:26 Regarding the RenderProcessHost* issue, the Render
pasko 2016/10/12 14:28:09 Thanks. We are prefetching a top-level frame only
pasko 2016/10/12 14:28:09 That's a good suggestion, thanks!
75 PrerenderHelper* helper = PrerenderHelper::Get(render_frame);
76 if (!helper)
77 return;
78 DCHECK_NE(helper->prerender_mode_, NO_PRERENDER);
79 helper->Send(new ViewHostMsg_PrefetchFinished());
80 }
81
72 bool PrerenderHelper::OnMessageReceived( 82 bool PrerenderHelper::OnMessageReceived(
73 const IPC::Message& message) { 83 const IPC::Message& message) {
74 IPC_BEGIN_MESSAGE_MAP(PrerenderHelper, message) 84 IPC_BEGIN_MESSAGE_MAP(PrerenderHelper, message)
75 IPC_MESSAGE_HANDLER(PrerenderMsg_SetIsPrerendering, OnSetIsPrerendering) 85 IPC_MESSAGE_HANDLER(PrerenderMsg_SetIsPrerendering, OnSetIsPrerendering)
76 IPC_END_MESSAGE_MAP() 86 IPC_END_MESSAGE_MAP()
77 // Return false on PrerenderMsg_SetIsPrerendering so other observers can see 87 // Return false on PrerenderMsg_SetIsPrerendering so other observers can see
78 // the message. 88 // the message.
79 return false; 89 return false;
80 } 90 }
81 91
(...skipping 10 matching lines...) Expand all
92 delete this; 102 delete this;
93 103
94 UpdateVisibilityState(frame); 104 UpdateVisibilityState(frame);
95 } 105 }
96 106
97 void PrerenderHelper::OnDestruct() { 107 void PrerenderHelper::OnDestruct() {
98 delete this; 108 delete this;
99 } 109 }
100 110
101 } // namespace prerender 111 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698