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

Side by Side Diff: content/browser/android/render_widget_host_connector.cc

Issue 2792063003: Factor out RenderWidgetHostConnector (Closed)
Patch Set: private observer Created 3 years, 8 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
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "content/browser/android/render_widget_host_connector.h"
6
7 #include "content/browser/frame_host/interstitial_page_impl.h"
8 #include "content/browser/renderer_host/render_widget_host_view_android.h"
9 #include "content/browser/web_contents/web_contents_impl.h"
10
11 namespace content {
12
13 // Observes RenderWidgetHostViewAndroid to keep the instance up to date.
14 class RenderWidgetHostConnector::Observer
15 : public WebContentsObserver,
16 public RenderWidgetHostViewAndroid::DestructionObserver {
17 public:
18 Observer(WebContents* web_contents, RenderWidgetHostConnector* connector);
19 ~Observer() override;
20
21 // WebContentsObserver implementation.
22 void RenderViewHostChanged(RenderViewHost* old_host,
23 RenderViewHost* new_host) override;
24 void DidAttachInterstitialPage() override;
25 void DidDetachInterstitialPage() override;
26 void WebContentsDestroyed() override;
27
28 // RenderWidgetHostViewAndroid::DestructionObserver implementation.
29 void RenderWidgetHostViewDestroyed(
30 RenderWidgetHostViewAndroid* rwhva) override;
31
32 RenderWidgetHostViewAndroid* rwhva() const { return rwhva_; }
33
34 private:
35 void UpdateRenderWidgetHostView(RenderWidgetHostViewAndroid* new_rwhva);
36 RenderWidgetHostViewAndroid* GetRenderWidgetHostViewAndroid() const;
37
38 RenderWidgetHostConnector* const connector_;
39 RenderWidgetHostViewAndroid* rwhva_;
40
41 DISALLOW_COPY_AND_ASSIGN(Observer);
42 };
43
44 RenderWidgetHostConnector::Observer::Observer(
45 WebContents* web_contents,
46 RenderWidgetHostConnector* connector)
47 : WebContentsObserver(web_contents),
48 connector_(connector),
49 rwhva_(nullptr) {}
50
51 RenderWidgetHostConnector::Observer::~Observer() {}
boliu 2017/04/14 01:10:07 DCHECK(rwhva_) is null here
Jinsuk Kim 2017/04/14 02:16:33 Done.
52
53 void RenderWidgetHostConnector::Observer::RenderViewHostChanged(
54 RenderViewHost* old_host,
55 RenderViewHost* new_host) {
56 auto* old_view = old_host ? static_cast<RenderWidgetHostViewAndroid*>(
57 old_host->GetWidget()->GetView())
58 : nullptr;
59 auto* new_view = new_host ? static_cast<RenderWidgetHostViewAndroid*>(
60 new_host->GetWidget()->GetView())
61 : nullptr;
62 DCHECK_EQ(old_view, rwhva_);
63 UpdateRenderWidgetHostView(new_view);
64 }
65
66 void RenderWidgetHostConnector::Observer::DidAttachInterstitialPage() {
67 UpdateRenderWidgetHostView(GetRenderWidgetHostViewAndroid());
68 }
69
70 void RenderWidgetHostConnector::Observer::DidDetachInterstitialPage() {
71 UpdateRenderWidgetHostView(GetRenderWidgetHostViewAndroid());
72 }
73
74 void RenderWidgetHostConnector::Observer::WebContentsDestroyed() {
75 DCHECK_EQ(rwhva_, GetRenderWidgetHostViewAndroid());
76 UpdateRenderWidgetHostView(nullptr);
77 delete connector_;
78 }
79
80 void RenderWidgetHostConnector::Observer::RenderWidgetHostViewDestroyed(
81 RenderWidgetHostViewAndroid* destroyed_rwhva) {
82 if (rwhva_ == destroyed_rwhva) {
83 // Null out the raw pointers here and in the connector impl to keep
84 // them from referencing the rwvha about to be destroyed.
85 connector_->UpdateRenderProcessConnection(rwhva_, nullptr);
86 rwhva_ = nullptr;
87 }
88 }
89
90 void RenderWidgetHostConnector::Observer::UpdateRenderWidgetHostView(
91 RenderWidgetHostViewAndroid* new_rwhva) {
92 if (rwhva_ == new_rwhva)
93 return;
94 if (rwhva_)
95 rwhva_->RemoveDestructionObserver(this);
96 if (new_rwhva)
97 new_rwhva->AddDestructionObserver(this);
98
99 connector_->UpdateRenderProcessConnection(rwhva_, new_rwhva);
100 rwhva_ = new_rwhva;
101 }
102
103 RenderWidgetHostViewAndroid*
104 RenderWidgetHostConnector::Observer::GetRenderWidgetHostViewAndroid() const {
105 RenderWidgetHostView* rwhv = web_contents()->GetRenderWidgetHostView();
106 WebContentsImpl* web_contents_impl =
107 static_cast<WebContentsImpl*>(web_contents());
108 if (web_contents_impl->ShowingInterstitialPage()) {
109 rwhv = web_contents_impl->GetInterstitialPage()
110 ->GetMainFrame()
111 ->GetRenderViewHost()
112 ->GetWidget()
113 ->GetView();
114 }
115 return static_cast<RenderWidgetHostViewAndroid*>(rwhv);
116 }
117
118 RenderWidgetHostConnector::RenderWidgetHostConnector(WebContents* web_contents)
119 : render_widget_observer_(
120 new RenderWidgetHostConnector::Observer(web_contents, this)) {}
boliu 2017/04/14 01:10:07 is namespace here required?
Jinsuk Kim 2017/04/14 02:16:33 No. removed.
121
122 RenderWidgetHostConnector::~RenderWidgetHostConnector() {}
123
124 RenderWidgetHostViewAndroid*
125 RenderWidgetHostConnector::GetRenderWidgetHostViewAndroidForTesting() const {
126 return render_widget_observer_->rwhva();
127 }
128
129 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698