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

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

Issue 2172613002: Renderer-side changes for NoState Prefetch (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 4 years, 4 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/public/renderer/document_state.h" 10 #include "content/public/renderer/document_state.h"
(...skipping 16 matching lines...) Expand all
27 if (render_view->GetMainRenderFrame() == render_frame) { 27 if (render_view->GetMainRenderFrame() == render_frame) {
28 render_view->GetWebView()->setVisibilityState( 28 render_view->GetWebView()->setVisibilityState(
29 render_frame->GetVisibilityState(), false); 29 render_frame->GetVisibilityState(), false);
30 } 30 }
31 } 31 }
32 32
33 } // namespace 33 } // namespace
34 34
35 namespace prerender { 35 namespace prerender {
36 36
37 PrerenderHelper::PrerenderHelper(content::RenderFrame* render_frame) 37 PrerenderHelper::PrerenderHelper(content::RenderFrame* render_frame,
38 PrerenderMode prerender_mode)
38 : content::RenderFrameObserver(render_frame), 39 : content::RenderFrameObserver(render_frame),
39 content::RenderFrameObserverTracker<PrerenderHelper>(render_frame) { 40 content::RenderFrameObserverTracker<PrerenderHelper>(render_frame),
41 prerender_mode_(prerender_mode) {
42 DCHECK_NE(prerender_mode_, NO_PRERENDER);
40 UpdateVisibilityState(render_frame); 43 UpdateVisibilityState(render_frame);
41 } 44 }
42 45
46 PrerenderHelper::PrerenderHelper(content::RenderFrame* sub_frame)
47 : PrerenderHelper(sub_frame,
48 GetPrerenderMode(
49 sub_frame->GetRenderView()->GetMainRenderFrame())) {
mmenke 2016/08/19 16:42:50 DCHECK that render_frame is not the main render fr
droger 2016/08/22 09:30:06 Done.
50 }
51
43 PrerenderHelper::~PrerenderHelper() { 52 PrerenderHelper::~PrerenderHelper() {
44 } 53 }
45 54
46 // static. 55 // static.
47 bool PrerenderHelper::IsPrerendering(const content::RenderFrame* render_frame) { 56 bool PrerenderHelper::IsPrerendering(const content::RenderFrame* render_frame) {
48 return PrerenderHelper::Get(render_frame) != NULL; 57 return PrerenderHelper::GetPrerenderMode(render_frame) != NO_PRERENDER;
58 }
59
60 // static.
61 PrerenderMode PrerenderHelper::GetPrerenderMode(
62 const content::RenderFrame* render_frame) {
63 PrerenderHelper* helper = PrerenderHelper::Get(render_frame);
64 if (!helper)
65 return NO_PRERENDER;
66
67 DCHECK_NE(helper->prerender_mode_, NO_PRERENDER);
68 return helper->prerender_mode_;
49 } 69 }
50 70
51 bool PrerenderHelper::OnMessageReceived( 71 bool PrerenderHelper::OnMessageReceived(
52 const IPC::Message& message) { 72 const IPC::Message& message) {
53 IPC_BEGIN_MESSAGE_MAP(PrerenderHelper, message) 73 IPC_BEGIN_MESSAGE_MAP(PrerenderHelper, message)
54 IPC_MESSAGE_HANDLER(PrerenderMsg_SetIsPrerendering, OnSetIsPrerendering) 74 IPC_MESSAGE_HANDLER(PrerenderMsg_SetIsPrerendering, OnSetIsPrerendering)
55 IPC_END_MESSAGE_MAP() 75 IPC_END_MESSAGE_MAP()
56 // Return false on PrerenderMsg_SetIsPrerendering so other observers can see 76 // Return false on PrerenderMsg_SetIsPrerendering so other observers can see
57 // the message. 77 // the message.
58 return false; 78 return false;
(...skipping 12 matching lines...) Expand all
71 delete this; 91 delete this;
72 92
73 UpdateVisibilityState(frame); 93 UpdateVisibilityState(frame);
74 } 94 }
75 95
76 void PrerenderHelper::OnDestruct() { 96 void PrerenderHelper::OnDestruct() {
77 delete this; 97 delete this;
78 } 98 }
79 99
80 } // namespace prerender 100 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698