OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/frame_host/render_frame_host_manager.h" | 5 #include "content/browser/frame_host/render_frame_host_manager.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
138 } | 138 } |
139 | 139 |
140 RenderWidgetHostView* RenderFrameHostManager::GetRenderWidgetHostView() const { | 140 RenderWidgetHostView* RenderFrameHostManager::GetRenderWidgetHostView() const { |
141 if (interstitial_page_) | 141 if (interstitial_page_) |
142 return interstitial_page_->GetView(); | 142 return interstitial_page_->GetView(); |
143 if (render_frame_host_) | 143 if (render_frame_host_) |
144 return render_frame_host_->GetView(); | 144 return render_frame_host_->GetView(); |
145 return nullptr; | 145 return nullptr; |
146 } | 146 } |
147 | 147 |
148 bool RenderFrameHostManager::ForInnerDelegate() { | |
149 // TODO(lazyboy): Subframes inside inner WebContents needs to be tested and | |
150 // we have to make sure that IsMainFrame() check below is appropriate. See | |
151 // http://crbug.com/500957. | |
152 return frame_tree_node_->IsMainFrame() && | |
153 delegate_->GetOuterDelegateFrameTreeNodeID() != | |
154 FrameTreeNode::kFrameTreeNodeInvalidID; | |
155 } | |
156 | |
157 RenderWidgetHostImpl* | |
158 RenderFrameHostManager::GetOuterRenderWidgetHostForKeyboardInput() { | |
159 if (!ForInnerDelegate()) | |
160 return nullptr; | |
161 | |
162 FrameTreeNode* outer_contents_frame_tree_node = | |
163 FrameTreeNode::GloballyFindByID( | |
164 delegate_->GetOuterDelegateFrameTreeNodeID()); | |
165 return outer_contents_frame_tree_node->parent() | |
166 ->current_frame_host() | |
167 ->render_view_host(); | |
168 } | |
169 | |
148 RenderFrameProxyHost* RenderFrameHostManager::GetProxyToParent() { | 170 RenderFrameProxyHost* RenderFrameHostManager::GetProxyToParent() { |
149 if (frame_tree_node_->IsMainFrame()) | 171 if (frame_tree_node_->IsMainFrame()) |
150 return NULL; | 172 return NULL; |
151 | 173 |
152 RenderFrameProxyHostMap::iterator iter = | 174 RenderFrameProxyHostMap::iterator iter = |
153 proxy_hosts_.find(frame_tree_node_->parent() | 175 proxy_hosts_.find(frame_tree_node_->parent() |
154 ->render_manager() | 176 ->render_manager() |
155 ->current_frame_host() | 177 ->current_frame_host() |
156 ->GetSiteInstance() | 178 ->GetSiteInstance() |
157 ->GetId()); | 179 ->GetId()); |
158 if (iter == proxy_hosts_.end()) | 180 if (iter == proxy_hosts_.end()) |
159 return NULL; | 181 return NULL; |
160 | 182 |
161 return iter->second; | 183 return iter->second; |
162 } | 184 } |
163 | 185 |
186 RenderFrameProxyHost* RenderFrameHostManager::GetProxyToOuterDelegate() { | |
187 int outer_contents_frame_tree_node_id = | |
188 delegate_->GetOuterDelegateFrameTreeNodeID(); | |
189 FrameTreeNode* outer_contents_frame_tree_node = | |
190 FrameTreeNode::GloballyFindByID(outer_contents_frame_tree_node_id); | |
191 if (!outer_contents_frame_tree_node || | |
192 !outer_contents_frame_tree_node->parent()) { | |
193 return nullptr; | |
194 } | |
195 | |
196 return GetRenderFrameProxyHost(outer_contents_frame_tree_node->parent() | |
197 ->current_frame_host() | |
198 ->GetSiteInstance()); | |
199 } | |
200 | |
201 void RenderFrameHostManager::RemoveOuterDelegateFrame() { | |
nasko
2015/06/23 13:39:23
I also feel this method doesn't quite belong in RF
lazyboy
2015/06/23 23:00:00
I've added a TODO for this to move out of RFHM.
| |
202 FrameTreeNode* outer_delegate_frame_tree_node = | |
203 FrameTreeNode::GloballyFindByID( | |
204 delegate_->GetOuterDelegateFrameTreeNodeID()); | |
205 DCHECK(outer_delegate_frame_tree_node->parent()); | |
206 outer_delegate_frame_tree_node->frame_tree()->RemoveFrame( | |
207 outer_delegate_frame_tree_node); | |
208 } | |
209 | |
164 void RenderFrameHostManager::SetPendingWebUI(const GURL& url, int bindings) { | 210 void RenderFrameHostManager::SetPendingWebUI(const GURL& url, int bindings) { |
165 pending_web_ui_ = CreateWebUI(url, bindings); | 211 pending_web_ui_ = CreateWebUI(url, bindings); |
166 pending_and_current_web_ui_.reset(); | 212 pending_and_current_web_ui_.reset(); |
167 } | 213 } |
168 | 214 |
169 scoped_ptr<WebUIImpl> RenderFrameHostManager::CreateWebUI(const GURL& url, | 215 scoped_ptr<WebUIImpl> RenderFrameHostManager::CreateWebUI(const GURL& url, |
170 int bindings) { | 216 int bindings) { |
171 scoped_ptr<WebUIImpl> new_web_ui(delegate_->CreateWebUIForRenderManager(url)); | 217 scoped_ptr<WebUIImpl> new_web_ui(delegate_->CreateWebUIForRenderManager(url)); |
172 | 218 |
173 // If we have assigned (zero or more) bindings to this NavigationEntry in the | 219 // If we have assigned (zero or more) bindings to this NavigationEntry in the |
(...skipping 1466 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1640 return; | 1686 return; |
1641 | 1687 |
1642 // Recreate the opener chain. | 1688 // Recreate the opener chain. |
1643 int opener_route_id = CreateOpenerProxiesIfNeeded(instance); | 1689 int opener_route_id = CreateOpenerProxiesIfNeeded(instance); |
1644 RenderFrameProxyHost* proxy = GetRenderFrameProxyHost(instance); | 1690 RenderFrameProxyHost* proxy = GetRenderFrameProxyHost(instance); |
1645 InitRenderView(render_view_host, opener_route_id, proxy->GetRoutingID(), | 1691 InitRenderView(render_view_host, opener_route_id, proxy->GetRoutingID(), |
1646 false); | 1692 false); |
1647 proxy->set_render_frame_proxy_created(true); | 1693 proxy->set_render_frame_proxy_created(true); |
1648 } | 1694 } |
1649 | 1695 |
1696 void RenderFrameHostManager::CreateOuterDelegateProxy( | |
1697 SiteInstance* outer_contents_site_instance, | |
1698 RenderFrameHostImpl* render_frame_host) { | |
1699 CHECK(base::CommandLine::ForCurrentProcess()->HasSwitch( | |
1700 switches::kSitePerProcess)); | |
1701 RenderFrameProxyHost* proxy = new RenderFrameProxyHost( | |
1702 outer_contents_site_instance, nullptr, frame_tree_node_); | |
1703 proxy_hosts_[outer_contents_site_instance->GetId()] = proxy; | |
1704 | |
1705 // Swap the outer WebContents's frame with the proxy to inner WebContents. | |
1706 render_frame_host->Send(new FrameMsg_SwapOut( | |
1707 render_frame_host->GetRoutingID(), proxy->GetRoutingID(), | |
1708 false /* is_loading */, FrameReplicationState())); | |
nasko
2015/06/23 13:39:23
nit: Do we still need a TODO for the is_loading?
lazyboy
2015/06/23 23:00:00
Done.
| |
1709 proxy->set_render_frame_proxy_created(true); | |
1710 } | |
1711 | |
1712 void RenderFrameHostManager::SetRWHViewForInnerContents( | |
1713 RenderWidgetHostView* child_rwhv) { | |
1714 DCHECK(ForInnerDelegate()); | |
1715 GetProxyToOuterDelegate()->SetChildRWHView(child_rwhv); | |
1716 } | |
1717 | |
1650 bool RenderFrameHostManager::InitRenderView( | 1718 bool RenderFrameHostManager::InitRenderView( |
1651 RenderViewHostImpl* render_view_host, | 1719 RenderViewHostImpl* render_view_host, |
1652 int opener_route_id, | 1720 int opener_route_id, |
1653 int proxy_routing_id, | 1721 int proxy_routing_id, |
1654 bool for_main_frame_navigation) { | 1722 bool for_main_frame_navigation) { |
1655 // Ensure the renderer process is initialized before creating the | 1723 // Ensure the renderer process is initialized before creating the |
1656 // RenderView. | 1724 // RenderView. |
1657 if (!render_view_host->GetProcess()->Init()) | 1725 if (!render_view_host->GetProcess()->Init()) |
1658 return false; | 1726 return false; |
1659 | 1727 |
(...skipping 578 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2238 frame_tree->root()->render_manager()-> | 2306 frame_tree->root()->render_manager()-> |
2239 CreateRenderFrame(instance, nullptr, opener_route_id, | 2307 CreateRenderFrame(instance, nullptr, opener_route_id, |
2240 CREATE_RF_FOR_MAIN_FRAME_NAVIGATION | | 2308 CREATE_RF_FOR_MAIN_FRAME_NAVIGATION | |
2241 CREATE_RF_SWAPPED_OUT | CREATE_RF_HIDDEN, | 2309 CREATE_RF_SWAPPED_OUT | CREATE_RF_HIDDEN, |
2242 &render_view_routing_id); | 2310 &render_view_routing_id); |
2243 } | 2311 } |
2244 return render_view_routing_id; | 2312 return render_view_routing_id; |
2245 } | 2313 } |
2246 | 2314 |
2247 } // namespace content | 2315 } // namespace content |
OLD | NEW |