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_impl.h" | 5 #include "content/browser/frame_host/render_frame_host_impl.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/containers/hash_tables.h" | 9 #include "base/containers/hash_tables.h" |
10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
112 int routing_id) { | 112 int routing_id) { |
113 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 113 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
114 RoutingIDFrameMap* frames = g_routing_id_frame_map.Pointer(); | 114 RoutingIDFrameMap* frames = g_routing_id_frame_map.Pointer(); |
115 RoutingIDFrameMap::iterator it = frames->find( | 115 RoutingIDFrameMap::iterator it = frames->find( |
116 RenderFrameHostID(process_id, routing_id)); | 116 RenderFrameHostID(process_id, routing_id)); |
117 return it == frames->end() ? NULL : it->second; | 117 return it == frames->end() ? NULL : it->second; |
118 } | 118 } |
119 | 119 |
120 RenderFrameHostImpl::RenderFrameHostImpl(RenderViewHostImpl* render_view_host, | 120 RenderFrameHostImpl::RenderFrameHostImpl(RenderViewHostImpl* render_view_host, |
121 RenderFrameHostDelegate* delegate, | 121 RenderFrameHostDelegate* delegate, |
122 RenderWidgetHostDelegate* rwh_delegate, | |
122 FrameTree* frame_tree, | 123 FrameTree* frame_tree, |
123 FrameTreeNode* frame_tree_node, | 124 FrameTreeNode* frame_tree_node, |
124 int routing_id, | 125 int routing_id, |
125 int flags) | 126 int flags) |
126 : render_view_host_(render_view_host), | 127 : render_view_host_(render_view_host), |
127 delegate_(delegate), | 128 delegate_(delegate), |
128 cross_process_frame_connector_(NULL), | 129 cross_process_frame_connector_(NULL), |
129 render_frame_proxy_host_(NULL), | 130 render_frame_proxy_host_(NULL), |
130 frame_tree_(frame_tree), | 131 frame_tree_(frame_tree), |
131 frame_tree_node_(frame_tree_node), | 132 frame_tree_node_(frame_tree_node), |
132 routing_id_(routing_id), | 133 routing_id_(routing_id), |
133 render_frame_created_(false), | 134 render_frame_created_(false), |
134 navigations_suspended_(false), | 135 navigations_suspended_(false), |
135 is_waiting_for_beforeunload_ack_(false), | 136 is_waiting_for_beforeunload_ack_(false), |
136 unload_ack_is_for_cross_site_transition_(false), | 137 unload_ack_is_for_cross_site_transition_(false), |
137 accessibility_reset_token_(0), | 138 accessibility_reset_token_(0), |
138 accessibility_reset_count_(0), | 139 accessibility_reset_count_(0), |
139 no_create_browser_accessibility_manager_for_testing_(false), | 140 no_create_browser_accessibility_manager_for_testing_(false), |
140 weak_ptr_factory_(this) { | 141 weak_ptr_factory_(this) { |
141 bool is_swapped_out = !!(flags & CREATE_RF_SWAPPED_OUT); | 142 bool is_swapped_out = !!(flags & CREATE_RF_SWAPPED_OUT); |
143 bool hidden = !!(flags & CREATE_RF_HIDDEN); | |
142 frame_tree_->RegisterRenderFrameHost(this); | 144 frame_tree_->RegisterRenderFrameHost(this); |
143 GetProcess()->AddRoute(routing_id_, this); | 145 GetProcess()->AddRoute(routing_id_, this); |
144 g_routing_id_frame_map.Get().insert(std::make_pair( | 146 g_routing_id_frame_map.Get().insert(std::make_pair( |
145 RenderFrameHostID(GetProcess()->GetID(), routing_id_), | 147 RenderFrameHostID(GetProcess()->GetID(), routing_id_), |
146 this)); | 148 this)); |
147 | 149 |
148 if (is_swapped_out) { | 150 if (is_swapped_out) { |
149 rfh_state_ = STATE_SWAPPED_OUT; | 151 rfh_state_ = STATE_SWAPPED_OUT; |
150 } else { | 152 } else { |
151 rfh_state_ = STATE_DEFAULT; | 153 rfh_state_ = STATE_DEFAULT; |
152 GetSiteInstance()->increment_active_frame_count(); | 154 GetSiteInstance()->increment_active_frame_count(); |
153 } | 155 } |
154 | 156 |
155 SetUpMojoIfNeeded(); | 157 SetUpMojoIfNeeded(); |
156 swapout_event_monitor_timeout_.reset(new TimeoutMonitor(base::Bind( | 158 swapout_event_monitor_timeout_.reset(new TimeoutMonitor(base::Bind( |
157 &RenderFrameHostImpl::OnSwappedOut, weak_ptr_factory_.GetWeakPtr()))); | 159 &RenderFrameHostImpl::OnSwappedOut, weak_ptr_factory_.GetWeakPtr()))); |
160 | |
161 if (flags & CREATE_RF_NEEDS_RENDER_WIDGET_HOST) { | |
162 render_widget_host_.reset(new RenderWidgetHostImpl( | |
163 rwh_delegate, GetProcess(), MSG_ROUTING_NONE, hidden)); | |
164 render_widget_host_->set_owned_by_render_frame_host(true); | |
165 } | |
158 } | 166 } |
159 | 167 |
160 RenderFrameHostImpl::~RenderFrameHostImpl() { | 168 RenderFrameHostImpl::~RenderFrameHostImpl() { |
161 GetProcess()->RemoveRoute(routing_id_); | 169 GetProcess()->RemoveRoute(routing_id_); |
162 g_routing_id_frame_map.Get().erase( | 170 g_routing_id_frame_map.Get().erase( |
163 RenderFrameHostID(GetProcess()->GetID(), routing_id_)); | 171 RenderFrameHostID(GetProcess()->GetID(), routing_id_)); |
164 | 172 |
165 if (delegate_) | 173 if (delegate_) |
166 delegate_->RenderFrameDeleted(this); | 174 delegate_->RenderFrameDeleted(this); |
167 | 175 |
168 FrameAccessibility::GetInstance()->OnRenderFrameHostDestroyed(this); | 176 FrameAccessibility::GetInstance()->OnRenderFrameHostDestroyed(this); |
169 | 177 |
170 // If this was swapped out, it already decremented the active frame count of | 178 // If this was swapped out, it already decremented the active frame count of |
171 // the SiteInstance it belongs to. | 179 // the SiteInstance it belongs to. |
172 if (IsRFHStateActive(rfh_state_)) | 180 if (IsRFHStateActive(rfh_state_)) |
173 GetSiteInstance()->decrement_active_frame_count(); | 181 GetSiteInstance()->decrement_active_frame_count(); |
174 | 182 |
175 // Notify the FrameTree that this RFH is going away, allowing it to shut down | 183 // Notify the FrameTree that this RFH is going away, allowing it to shut down |
176 // the corresponding RenderViewHost if it is no longer needed. | 184 // the corresponding RenderViewHost if it is no longer needed. |
177 frame_tree_->UnregisterRenderFrameHost(this); | 185 frame_tree_->UnregisterRenderFrameHost(this); |
178 | 186 |
179 // NULL out the swapout timer; in crash dumps this member will be null only if | 187 // NULL out the swapout timer; in crash dumps this member will be null only if |
180 // the dtor has run. | 188 // the dtor has run. |
181 swapout_event_monitor_timeout_.reset(); | 189 swapout_event_monitor_timeout_.reset(); |
190 | |
191 if (render_widget_host_) | |
192 render_widget_host_->Cleanup(); | |
Charlie Reis
2015/01/15 23:06:27
nit: 2 space indent in Chromium.
kenrb
2015/01/16 17:44:00
Done.
| |
182 } | 193 } |
183 | 194 |
184 int RenderFrameHostImpl::GetRoutingID() { | 195 int RenderFrameHostImpl::GetRoutingID() { |
185 return routing_id_; | 196 return routing_id_; |
186 } | 197 } |
187 | 198 |
188 SiteInstanceImpl* RenderFrameHostImpl::GetSiteInstance() { | 199 SiteInstanceImpl* RenderFrameHostImpl::GetSiteInstance() { |
189 return render_view_host_->GetSiteInstance(); | 200 return render_view_host_->GetSiteInstance(); |
190 } | 201 } |
191 | 202 |
(...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
502 | 513 |
503 // The process may (if we're sharing a process with another host that already | 514 // The process may (if we're sharing a process with another host that already |
504 // initialized it) or may not (we have our own process or the old process | 515 // initialized it) or may not (we have our own process or the old process |
505 // crashed) have been initialized. Calling Init multiple times will be | 516 // crashed) have been initialized. Calling Init multiple times will be |
506 // ignored, so this is safe. | 517 // ignored, so this is safe. |
507 if (!GetProcess()->Init()) | 518 if (!GetProcess()->Init()) |
508 return false; | 519 return false; |
509 | 520 |
510 DCHECK(GetProcess()->HasConnection()); | 521 DCHECK(GetProcess()->HasConnection()); |
511 | 522 |
512 Send(new FrameMsg_NewFrame(routing_id_, parent_routing_id, proxy_routing_id)); | 523 FrameMsg_NewFrame_WidgetParams widget_params; |
524 if (render_widget_host_) { | |
525 widget_params.routing_id = render_widget_host_->GetRoutingID(); | |
526 widget_params.surface_id = render_widget_host_->surface_id(); | |
527 widget_params.hidden = render_widget_host_->is_hidden(); | |
528 } else { | |
529 // MSG_ROUTING_NONE will prevent a new RenderWidget from being created in | |
530 // the renderer process. | |
531 widget_params.routing_id = MSG_ROUTING_NONE; | |
532 widget_params.surface_id = 0; | |
533 widget_params.hidden = true; | |
534 } | |
535 | |
536 Send(new FrameMsg_NewFrame(routing_id_, parent_routing_id, proxy_routing_id, | |
537 widget_params)); | |
538 | |
539 // The RenderWidgetHost takes ownership of its view. It is tied to the | |
540 // lifetime of the current RenderProcessHost for this RenderFrameHost. | |
541 if (render_widget_host_) { | |
542 RenderWidgetHostView* rwhv = | |
543 new RenderWidgetHostViewChildFrame(render_widget_host_.get()); | |
544 rwhv->Hide(); | |
545 } | |
513 | 546 |
514 // The renderer now has a RenderFrame for this RenderFrameHost. Note that | 547 // The renderer now has a RenderFrame for this RenderFrameHost. Note that |
515 // this path is only used for out-of-process iframes. Main frame RenderFrames | 548 // this path is only used for out-of-process iframes. Main frame RenderFrames |
516 // are created with their RenderView, and same-site iframes are created at the | 549 // are created with their RenderView, and same-site iframes are created at the |
517 // time of OnCreateChildFrame. | 550 // time of OnCreateChildFrame. |
518 set_render_frame_created(true); | 551 SetRenderFrameCreated(true); |
519 | 552 |
520 return true; | 553 return true; |
521 } | 554 } |
522 | 555 |
523 bool RenderFrameHostImpl::IsRenderFrameLive() { | 556 bool RenderFrameHostImpl::IsRenderFrameLive() { |
524 // RenderFrames are created for main frames at the same time as RenderViews, | 557 // RenderFrames are created for main frames at the same time as RenderViews, |
525 // so we rely on IsRenderViewLive. For subframes, we keep track of each | 558 // so we rely on IsRenderViewLive. For subframes, we keep track of each |
526 // RenderFrame individually with render_frame_created_. | 559 // RenderFrame individually with render_frame_created_. |
527 bool is_live = !GetParent() ? | 560 bool is_live = !GetParent() ? |
528 render_view_host_->IsRenderViewLive() : | 561 render_view_host_->IsRenderViewLive() : |
529 GetProcess()->HasConnection() && render_frame_created_; | 562 GetProcess()->HasConnection() && render_frame_created_; |
530 | 563 |
531 // Sanity check: the RenderView should always be live if the RenderFrame is. | 564 // Sanity check: the RenderView should always be live if the RenderFrame is. |
532 DCHECK(!is_live || render_view_host_->IsRenderViewLive()); | 565 DCHECK(!is_live || render_view_host_->IsRenderViewLive()); |
533 | 566 |
534 return is_live; | 567 return is_live; |
535 } | 568 } |
536 | 569 |
570 void RenderFrameHostImpl::SetRenderFrameCreated(bool created) { | |
571 render_frame_created_ = created; | |
Charlie Reis
2015/01/15 23:06:27
nit: 2 space indent in Chromium.
kenrb
2015/01/16 17:44:00
Done.
| |
572 if (created && render_widget_host_) | |
Charlie Reis
2015/01/15 23:06:27
Do we need to clear RenderWidgetHostImpl::renderer
kenrb
2015/01/16 17:44:00
This is a good point, the flag doesn't get reset.
| |
573 render_widget_host_->InitForFrame(); | |
574 } | |
575 | |
537 void RenderFrameHostImpl::Init() { | 576 void RenderFrameHostImpl::Init() { |
538 GetProcess()->ResumeRequestsForView(routing_id_); | 577 GetProcess()->ResumeRequestsForView(routing_id_); |
539 } | 578 } |
540 | 579 |
541 void RenderFrameHostImpl::OnAddMessageToConsole( | 580 void RenderFrameHostImpl::OnAddMessageToConsole( |
542 int32 level, | 581 int32 level, |
543 const base::string16& message, | 582 const base::string16& message, |
544 int32 line_no, | 583 int32 line_no, |
545 const base::string16& source_id) { | 584 const base::string16& source_id) { |
546 if (delegate_->AddMessageToConsole(level, message, line_no, source_id)) | 585 if (delegate_->AddMessageToConsole(level, message, line_no, source_id)) |
(...skipping 18 matching lines...) Expand all Loading... | |
565 if (rfh_state_ != RenderFrameHostImpl::STATE_DEFAULT) | 604 if (rfh_state_ != RenderFrameHostImpl::STATE_DEFAULT) |
566 return; | 605 return; |
567 | 606 |
568 RenderFrameHostImpl* new_frame = frame_tree_->AddFrame( | 607 RenderFrameHostImpl* new_frame = frame_tree_->AddFrame( |
569 frame_tree_node_, GetProcess()->GetID(), new_routing_id, frame_name); | 608 frame_tree_node_, GetProcess()->GetID(), new_routing_id, frame_name); |
570 if (!new_frame) | 609 if (!new_frame) |
571 return; | 610 return; |
572 | 611 |
573 // We know that the RenderFrame has been created in this case, immediately | 612 // We know that the RenderFrame has been created in this case, immediately |
574 // after the CreateChildFrame IPC was sent. | 613 // after the CreateChildFrame IPC was sent. |
575 new_frame->set_render_frame_created(true); | 614 new_frame->SetRenderFrameCreated(true); |
576 | 615 |
577 if (delegate_) | 616 if (delegate_) |
578 delegate_->RenderFrameCreated(new_frame); | 617 delegate_->RenderFrameCreated(new_frame); |
579 } | 618 } |
580 | 619 |
581 void RenderFrameHostImpl::OnDetach() { | 620 void RenderFrameHostImpl::OnDetach() { |
582 frame_tree_->RemoveFrame(frame_tree_node_); | 621 frame_tree_->RemoveFrame(frame_tree_node_); |
583 } | 622 } |
584 | 623 |
585 void RenderFrameHostImpl::OnFrameFocused() { | 624 void RenderFrameHostImpl::OnFrameFocused() { |
(...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
714 | 753 |
715 void RenderFrameHostImpl::OnDidDropNavigation() { | 754 void RenderFrameHostImpl::OnDidDropNavigation() { |
716 // At the end of Navigate(), the delegate's DidStartLoading is called to force | 755 // At the end of Navigate(), the delegate's DidStartLoading is called to force |
717 // the spinner to start, even if the renderer didn't yet begin the load. If it | 756 // the spinner to start, even if the renderer didn't yet begin the load. If it |
718 // turns out that the renderer dropped the navigation, we need to turn off the | 757 // turns out that the renderer dropped the navigation, we need to turn off the |
719 // spinner. | 758 // spinner. |
720 delegate_->DidStopLoading(this); | 759 delegate_->DidStopLoading(this); |
721 } | 760 } |
722 | 761 |
723 RenderWidgetHostImpl* RenderFrameHostImpl::GetRenderWidgetHost() { | 762 RenderWidgetHostImpl* RenderFrameHostImpl::GetRenderWidgetHost() { |
724 return static_cast<RenderWidgetHostImpl*>(render_view_host_); | 763 if (render_widget_host_) |
764 return render_widget_host_.get(); | |
765 | |
766 // TODO(kenrb): When RenderViewHost no longer inherits RenderWidgetHost, | |
767 // we can remove this fallback. Currently it is only used for the main | |
768 // frame. | |
769 if (!GetParent()) | |
770 return static_cast<RenderWidgetHostImpl*>(render_view_host_); | |
771 | |
772 return nullptr; | |
773 } | |
774 | |
775 RenderWidgetHostView* RenderFrameHostImpl::GetView() { | |
776 RenderFrameHostImpl* frame = this; | |
777 while (frame) { | |
778 if (frame->render_widget_host_) | |
779 return frame->render_widget_host_->GetView(); | |
780 frame = static_cast<RenderFrameHostImpl*>(frame->GetParent()); | |
781 } | |
782 | |
783 return render_view_host_->GetView(); | |
725 } | 784 } |
726 | 785 |
727 int RenderFrameHostImpl::GetEnabledBindings() { | 786 int RenderFrameHostImpl::GetEnabledBindings() { |
728 return render_view_host_->GetEnabledBindings(); | 787 return render_view_host_->GetEnabledBindings(); |
729 } | 788 } |
730 | 789 |
731 void RenderFrameHostImpl::OnCrossSiteResponse( | 790 void RenderFrameHostImpl::OnCrossSiteResponse( |
732 const GlobalRequestID& global_request_id, | 791 const GlobalRequestID& global_request_id, |
733 scoped_ptr<CrossSiteTransferringRequest> cross_site_transferring_request, | 792 scoped_ptr<CrossSiteTransferringRequest> cross_site_transferring_request, |
734 const std::vector<GURL>& transfer_url_chain, | 793 const std::vector<GURL>& transfer_url_chain, |
(...skipping 873 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1608 void RenderFrameHostImpl::DidUseGeolocationPermission() { | 1667 void RenderFrameHostImpl::DidUseGeolocationPermission() { |
1609 RenderFrameHost* top_frame = frame_tree_node()->frame_tree()->GetMainFrame(); | 1668 RenderFrameHost* top_frame = frame_tree_node()->frame_tree()->GetMainFrame(); |
1610 GetContentClient()->browser()->RegisterPermissionUsage( | 1669 GetContentClient()->browser()->RegisterPermissionUsage( |
1611 PERMISSION_GEOLOCATION, | 1670 PERMISSION_GEOLOCATION, |
1612 delegate_->GetAsWebContents(), | 1671 delegate_->GetAsWebContents(), |
1613 GetLastCommittedURL().GetOrigin(), | 1672 GetLastCommittedURL().GetOrigin(), |
1614 top_frame->GetLastCommittedURL().GetOrigin()); | 1673 top_frame->GetLastCommittedURL().GetOrigin()); |
1615 } | 1674 } |
1616 | 1675 |
1617 } // namespace content | 1676 } // namespace content |
OLD | NEW |