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/containers/hash_tables.h" | 8 #include "base/containers/hash_tables.h" |
9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
10 #include "base/metrics/user_metrics_action.h" | 10 #include "base/metrics/user_metrics_action.h" |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
137 } | 137 } |
138 | 138 |
139 } // namespace | 139 } // namespace |
140 | 140 |
141 RenderFrameHost* RenderFrameHost::FromID(int render_process_id, | 141 RenderFrameHost* RenderFrameHost::FromID(int render_process_id, |
142 int render_frame_id) { | 142 int render_frame_id) { |
143 return RenderFrameHostImpl::FromID(render_process_id, render_frame_id); | 143 return RenderFrameHostImpl::FromID(render_process_id, render_frame_id); |
144 } | 144 } |
145 | 145 |
146 // static | 146 // static |
147 RenderFrameHostImpl* RenderFrameHostImpl::FromID( | 147 RenderFrameHostImpl* RenderFrameHostImpl::FromID(int process_id, |
148 int process_id, int routing_id) { | 148 int routing_id) { |
149 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 149 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
150 RoutingIDFrameMap* frames = g_routing_id_frame_map.Pointer(); | 150 RoutingIDFrameMap* frames = g_routing_id_frame_map.Pointer(); |
151 RoutingIDFrameMap::iterator it = frames->find( | 151 RoutingIDFrameMap::iterator it = frames->find( |
152 RenderFrameHostID(process_id, routing_id)); | 152 RenderFrameHostID(process_id, routing_id)); |
153 return it == frames->end() ? NULL : it->second; | 153 return it == frames->end() ? NULL : it->second; |
154 } | 154 } |
155 | 155 |
156 RenderFrameHostImpl::RenderFrameHostImpl( | 156 RenderFrameHostImpl::RenderFrameHostImpl(RenderViewHostImpl* render_view_host, |
157 RenderViewHostImpl* render_view_host, | 157 RenderFrameHostDelegate* delegate, |
158 RenderFrameHostDelegate* delegate, | 158 FrameTree* frame_tree, |
159 FrameTree* frame_tree, | 159 FrameTreeNode* frame_tree_node, |
160 FrameTreeNode* frame_tree_node, | 160 int routing_id, |
161 int routing_id, | 161 bool is_swapped_out) |
162 bool is_swapped_out) | |
163 : render_view_host_(render_view_host), | 162 : render_view_host_(render_view_host), |
164 delegate_(delegate), | 163 delegate_(delegate), |
165 cross_process_frame_connector_(NULL), | 164 cross_process_frame_connector_(NULL), |
166 render_frame_proxy_host_(NULL), | 165 render_frame_proxy_host_(NULL), |
167 frame_tree_(frame_tree), | 166 frame_tree_(frame_tree), |
168 frame_tree_node_(frame_tree_node), | 167 frame_tree_node_(frame_tree_node), |
169 routing_id_(routing_id), | 168 routing_id_(routing_id), |
170 is_swapped_out_(is_swapped_out), | 169 is_swapped_out_(is_swapped_out), |
| 170 renderer_initialized_(false), |
171 weak_ptr_factory_(this) { | 171 weak_ptr_factory_(this) { |
172 frame_tree_->RegisterRenderFrameHost(this); | 172 frame_tree_->RegisterRenderFrameHost(this); |
173 GetProcess()->AddRoute(routing_id_, this); | 173 GetProcess()->AddRoute(routing_id_, this); |
174 g_routing_id_frame_map.Get().insert(std::make_pair( | 174 g_routing_id_frame_map.Get().insert(std::make_pair( |
175 RenderFrameHostID(GetProcess()->GetID(), routing_id_), | 175 RenderFrameHostID(GetProcess()->GetID(), routing_id_), |
176 this)); | 176 this)); |
177 | 177 |
178 if (GetProcess()->GetServiceRegistry()) { | 178 if (GetProcess()->GetServiceRegistry()) { |
179 RenderFrameSetupPtr setup; | 179 RenderFrameSetupPtr setup; |
180 GetProcess()->GetServiceRegistry()->ConnectToRemoteService(&setup); | 180 GetProcess()->GetServiceRegistry()->ConnectToRemoteService(&setup); |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
268 static_cast<RenderProcessHostImpl*>(GetProcess())->EnsureMojoActivated(); | 268 static_cast<RenderProcessHostImpl*>(GetProcess())->EnsureMojoActivated(); |
269 return &service_registry_; | 269 return &service_registry_; |
270 } | 270 } |
271 | 271 |
272 bool RenderFrameHostImpl::Send(IPC::Message* message) { | 272 bool RenderFrameHostImpl::Send(IPC::Message* message) { |
273 if (IPC_MESSAGE_ID_CLASS(message->type()) == InputMsgStart) { | 273 if (IPC_MESSAGE_ID_CLASS(message->type()) == InputMsgStart) { |
274 return render_view_host_->input_router()->SendInput( | 274 return render_view_host_->input_router()->SendInput( |
275 make_scoped_ptr(message)); | 275 make_scoped_ptr(message)); |
276 } | 276 } |
277 | 277 |
278 if (render_view_host_->IsSwappedOut()) { | 278 // Route IPCs through the RenderFrameProxyHost when in swapped out state. |
| 279 // Note: For subframes in --site-per-process mode, we don't use swapped out |
| 280 // RenderFrameHosts. |
| 281 if (frame_tree_node_->IsMainFrame() && render_view_host_->IsSwappedOut()) { |
279 DCHECK(render_frame_proxy_host_); | 282 DCHECK(render_frame_proxy_host_); |
280 return render_frame_proxy_host_->Send(message); | 283 return render_frame_proxy_host_->Send(message); |
281 } | 284 } |
282 | 285 |
283 return GetProcess()->Send(message); | 286 return GetProcess()->Send(message); |
284 } | 287 } |
285 | 288 |
286 bool RenderFrameHostImpl::OnMessageReceived(const IPC::Message &msg) { | 289 bool RenderFrameHostImpl::OnMessageReceived(const IPC::Message &msg) { |
287 // Filter out most IPC messages if this renderer is swapped out. | 290 // Filter out most IPC messages if this renderer is swapped out. |
288 // We still want to handle certain ACKs to keep our state consistent. | 291 // We still want to handle certain ACKs to keep our state consistent. |
(...skipping 153 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
442 | 445 |
443 gfx::NativeViewAccessible | 446 gfx::NativeViewAccessible |
444 RenderFrameHostImpl::AccessibilityGetNativeViewAccessible() { | 447 RenderFrameHostImpl::AccessibilityGetNativeViewAccessible() { |
445 RenderWidgetHostViewBase* view = static_cast<RenderWidgetHostViewBase*>( | 448 RenderWidgetHostViewBase* view = static_cast<RenderWidgetHostViewBase*>( |
446 render_view_host_->GetView()); | 449 render_view_host_->GetView()); |
447 if (view) | 450 if (view) |
448 return view->AccessibilityGetNativeViewAccessible(); | 451 return view->AccessibilityGetNativeViewAccessible(); |
449 return NULL; | 452 return NULL; |
450 } | 453 } |
451 | 454 |
| 455 bool RenderFrameHostImpl::CreateRenderFrame(int parent_routing_id) { |
| 456 TRACE_EVENT0("frame_host", "RenderFrameHostImpl::CreateRenderFrame"); |
| 457 DCHECK(!IsRenderFrameLive()) << "Creating frame twice"; |
| 458 |
| 459 // The process may (if we're sharing a process with another host that already |
| 460 // initialized it) or may not (we have our own process or the old process |
| 461 // crashed) have been initialized. Calling Init multiple times will be |
| 462 // ignored, so this is safe. |
| 463 if (!GetProcess()->Init()) |
| 464 return false; |
| 465 |
| 466 DCHECK(GetProcess()->HasConnection()); |
| 467 |
| 468 renderer_initialized_ = true; |
| 469 Send(new FrameMsg_NewFrame(routing_id_, parent_routing_id)); |
| 470 |
| 471 return true; |
| 472 } |
| 473 |
| 474 bool RenderFrameHostImpl::IsRenderFrameLive() { |
| 475 return GetProcess()->HasConnection() && renderer_initialized_; |
| 476 } |
| 477 |
452 void RenderFrameHostImpl::Init() { | 478 void RenderFrameHostImpl::Init() { |
453 GetProcess()->ResumeRequestsForView(routing_id_); | 479 GetProcess()->ResumeRequestsForView(routing_id_); |
454 } | 480 } |
455 | 481 |
456 void RenderFrameHostImpl::OnAddMessageToConsole( | 482 void RenderFrameHostImpl::OnAddMessageToConsole( |
457 int32 level, | 483 int32 level, |
458 const base::string16& message, | 484 const base::string16& message, |
459 int32 line_no, | 485 int32 line_no, |
460 const base::string16& source_id) { | 486 const base::string16& source_id) { |
461 if (delegate_->AddMessageToConsole(level, message, line_no, source_id)) | 487 if (delegate_->AddMessageToConsole(level, message, line_no, source_id)) |
(...skipping 421 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
883 WebTextDirectionToChromeTextDirection( | 909 WebTextDirectionToChromeTextDirection( |
884 title_direction)); | 910 title_direction)); |
885 } | 911 } |
886 | 912 |
887 void RenderFrameHostImpl::OnUpdateEncoding(const std::string& encoding_name) { | 913 void RenderFrameHostImpl::OnUpdateEncoding(const std::string& encoding_name) { |
888 // This message is only sent for top-level frames. TODO(avi): when frame tree | 914 // This message is only sent for top-level frames. TODO(avi): when frame tree |
889 // mirroring works correctly, add a check here to enforce it. | 915 // mirroring works correctly, add a check here to enforce it. |
890 delegate_->UpdateEncoding(this, encoding_name); | 916 delegate_->UpdateEncoding(this, encoding_name); |
891 } | 917 } |
892 | 918 |
893 | |
894 void RenderFrameHostImpl::OnBeginNavigation( | 919 void RenderFrameHostImpl::OnBeginNavigation( |
895 const FrameHostMsg_BeginNavigation_Params& params) { | 920 const FrameHostMsg_BeginNavigation_Params& params) { |
896 #if defined(USE_BROWSER_SIDE_NAVIGATION) | 921 #if defined(USE_BROWSER_SIDE_NAVIGATION) |
897 frame_tree_node()->render_manager()->OnBeginNavigation(params); | 922 frame_tree_node()->render_manager()->OnBeginNavigation(params); |
898 #endif | 923 #endif |
899 } | 924 } |
900 | 925 |
901 void RenderFrameHostImpl::OnAccessibilityEvents( | 926 void RenderFrameHostImpl::OnAccessibilityEvents( |
902 const std::vector<AccessibilityHostMsg_EventParams>& params) { | 927 const std::vector<AccessibilityHostMsg_EventParams>& params) { |
903 RenderWidgetHostViewBase* view = static_cast<RenderWidgetHostViewBase*>( | 928 RenderWidgetHostViewBase* view = static_cast<RenderWidgetHostViewBase*>( |
904 render_view_host_->GetView()); | 929 render_view_host_->GetView()); |
905 | 930 |
906 | |
907 AccessibilityMode accessibility_mode = delegate_->GetAccessibilityMode(); | 931 AccessibilityMode accessibility_mode = delegate_->GetAccessibilityMode(); |
908 if ((accessibility_mode != AccessibilityModeOff) && view && | 932 if ((accessibility_mode != AccessibilityModeOff) && view && |
909 RenderViewHostImpl::IsRVHStateActive(render_view_host_->rvh_state())) { | 933 RenderViewHostImpl::IsRVHStateActive(render_view_host_->rvh_state())) { |
910 if (accessibility_mode & AccessibilityModeFlagPlatform) { | 934 if (accessibility_mode & AccessibilityModeFlagPlatform) { |
911 GetOrCreateBrowserAccessibilityManager(); | 935 GetOrCreateBrowserAccessibilityManager(); |
912 if (browser_accessibility_manager_) | 936 if (browser_accessibility_manager_) |
913 browser_accessibility_manager_->OnAccessibilityEvents(params); | 937 browser_accessibility_manager_->OnAccessibilityEvents(params); |
914 } | 938 } |
915 | 939 |
916 std::vector<AXEventNotificationDetails> details; | 940 std::vector<AXEventNotificationDetails> details; |
(...skipping 274 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1191 FROM_HERE, | 1215 FROM_HERE, |
1192 base::Bind( | 1216 base::Bind( |
1193 &TransitionRequestManager::SetHasPendingTransitionRequest, | 1217 &TransitionRequestManager::SetHasPendingTransitionRequest, |
1194 base::Unretained(TransitionRequestManager::GetInstance()), | 1218 base::Unretained(TransitionRequestManager::GetInstance()), |
1195 GetProcess()->GetID(), | 1219 GetProcess()->GetID(), |
1196 routing_id_, | 1220 routing_id_, |
1197 has_pending_request)); | 1221 has_pending_request)); |
1198 } | 1222 } |
1199 | 1223 |
1200 } // namespace content | 1224 } // namespace content |
OLD | NEW |