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

Side by Side Diff: content/renderer/render_thread_impl.cc

Issue 404613005: Start using RenderFrameProxyHost objects. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Bug fix + ncarter review comments addressed Created 6 years, 5 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 | Annotate | Revision Log
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 "content/renderer/render_thread_impl.h" 5 #include "content/renderer/render_thread_impl.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <limits> 8 #include <limits>
9 #include <map> 9 #include <map>
10 #include <vector> 10 #include <vector>
(...skipping 29 matching lines...) Expand all
40 #include "content/child/plugin_messages.h" 40 #include "content/child/plugin_messages.h"
41 #include "content/child/resource_dispatcher.h" 41 #include "content/child/resource_dispatcher.h"
42 #include "content/child/runtime_features.h" 42 #include "content/child/runtime_features.h"
43 #include "content/child/thread_safe_sender.h" 43 #include "content/child/thread_safe_sender.h"
44 #include "content/child/web_database_observer_impl.h" 44 #include "content/child/web_database_observer_impl.h"
45 #include "content/child/worker_task_runner.h" 45 #include "content/child/worker_task_runner.h"
46 #include "content/common/child_process_messages.h" 46 #include "content/common/child_process_messages.h"
47 #include "content/common/content_constants_internal.h" 47 #include "content/common/content_constants_internal.h"
48 #include "content/common/database_messages.h" 48 #include "content/common/database_messages.h"
49 #include "content/common/dom_storage/dom_storage_messages.h" 49 #include "content/common/dom_storage/dom_storage_messages.h"
50 #include "content/common/frame_messages.h"
50 #include "content/common/gpu/client/context_provider_command_buffer.h" 51 #include "content/common/gpu/client/context_provider_command_buffer.h"
51 #include "content/common/gpu/client/gpu_channel_host.h" 52 #include "content/common/gpu/client/gpu_channel_host.h"
52 #include "content/common/gpu/client/gpu_memory_buffer_impl.h" 53 #include "content/common/gpu/client/gpu_memory_buffer_impl.h"
53 #include "content/common/gpu/gpu_messages.h" 54 #include "content/common/gpu/gpu_messages.h"
54 #include "content/common/gpu/gpu_process_launch_causes.h" 55 #include "content/common/gpu/gpu_process_launch_causes.h"
55 #include "content/common/render_frame_setup.mojom.h" 56 #include "content/common/render_frame_setup.mojom.h"
56 #include "content/common/resource_messages.h" 57 #include "content/common/resource_messages.h"
57 #include "content/common/view_messages.h" 58 #include "content/common/view_messages.h"
58 #include "content/common/worker_messages.h" 59 #include "content/common/worker_messages.h"
59 #include "content/public/common/content_constants.h" 60 #include "content/public/common/content_constants.h"
(...skipping 23 matching lines...) Expand all
83 #include "content/renderer/media/midi_message_filter.h" 84 #include "content/renderer/media/midi_message_filter.h"
84 #include "content/renderer/media/peer_connection_tracker.h" 85 #include "content/renderer/media/peer_connection_tracker.h"
85 #include "content/renderer/media/renderer_gpu_video_accelerator_factories.h" 86 #include "content/renderer/media/renderer_gpu_video_accelerator_factories.h"
86 #include "content/renderer/media/rtc_peer_connection_handler.h" 87 #include "content/renderer/media/rtc_peer_connection_handler.h"
87 #include "content/renderer/media/video_capture_impl_manager.h" 88 #include "content/renderer/media/video_capture_impl_manager.h"
88 #include "content/renderer/media/video_capture_message_filter.h" 89 #include "content/renderer/media/video_capture_message_filter.h"
89 #include "content/renderer/media/webrtc/peer_connection_dependency_factory.h" 90 #include "content/renderer/media/webrtc/peer_connection_dependency_factory.h"
90 #include "content/renderer/media/webrtc_identity_service.h" 91 #include "content/renderer/media/webrtc_identity_service.h"
91 #include "content/renderer/net_info_helper.h" 92 #include "content/renderer/net_info_helper.h"
92 #include "content/renderer/p2p/socket_dispatcher.h" 93 #include "content/renderer/p2p/socket_dispatcher.h"
94 #include "content/renderer/render_frame_proxy.h"
93 #include "content/renderer/render_process_impl.h" 95 #include "content/renderer/render_process_impl.h"
94 #include "content/renderer/render_view_impl.h" 96 #include "content/renderer/render_view_impl.h"
95 #include "content/renderer/renderer_webkitplatformsupport_impl.h" 97 #include "content/renderer/renderer_webkitplatformsupport_impl.h"
96 #include "content/renderer/service_worker/embedded_worker_context_message_filter .h" 98 #include "content/renderer/service_worker/embedded_worker_context_message_filter .h"
97 #include "content/renderer/service_worker/embedded_worker_dispatcher.h" 99 #include "content/renderer/service_worker/embedded_worker_dispatcher.h"
98 #include "content/renderer/shared_worker/embedded_shared_worker_stub.h" 100 #include "content/renderer/shared_worker/embedded_shared_worker_stub.h"
99 #include "grit/content_resources.h" 101 #include "grit/content_resources.h"
100 #include "ipc/ipc_channel_handle.h" 102 #include "ipc/ipc_channel_handle.h"
101 #include "ipc/ipc_forwarding_message_filter.h" 103 #include "ipc/ipc_forwarding_message_filter.h"
102 #include "ipc/ipc_platform_file.h" 104 #include "ipc/ipc_platform_file.h"
(...skipping 1164 matching lines...) Expand 10 before | Expand all | Expand 10 after
1267 } 1269 }
1268 1270
1269 void RenderThreadImpl::DoNotSuspendWebKitSharedTimer() { 1271 void RenderThreadImpl::DoNotSuspendWebKitSharedTimer() {
1270 suspend_webkit_shared_timer_ = false; 1272 suspend_webkit_shared_timer_ = false;
1271 } 1273 }
1272 1274
1273 void RenderThreadImpl::DoNotNotifyWebKitOfModalLoop() { 1275 void RenderThreadImpl::DoNotNotifyWebKitOfModalLoop() {
1274 notify_webkit_of_modal_loop_ = false; 1276 notify_webkit_of_modal_loop_ = false;
1275 } 1277 }
1276 1278
1277 void RenderThreadImpl::OnSetZoomLevelForCurrentURL(const std::string& scheme,
Charlie Reis 2014/07/24 22:36:32 Is this from a merge conflict? It seems unrelated
nasko 2014/07/25 07:13:21 I moved it to be ordered according to the .h file.
1278 const std::string& host,
1279 double zoom_level) {
1280 RenderViewZoomer zoomer(scheme, host, zoom_level);
1281 RenderView::ForEach(&zoomer);
1282 }
1283
1284 bool RenderThreadImpl::OnControlMessageReceived(const IPC::Message& msg) { 1279 bool RenderThreadImpl::OnControlMessageReceived(const IPC::Message& msg) {
1285 ObserverListBase<RenderProcessObserver>::Iterator it(observers_); 1280 ObserverListBase<RenderProcessObserver>::Iterator it(observers_);
1286 RenderProcessObserver* observer; 1281 RenderProcessObserver* observer;
1287 while ((observer = it.GetNext()) != NULL) { 1282 while ((observer = it.GetNext()) != NULL) {
1288 if (observer->OnControlMessageReceived(msg)) 1283 if (observer->OnControlMessageReceived(msg))
1289 return true; 1284 return true;
1290 } 1285 }
1291 1286
1292 // Some messages are handled by delegates. 1287 // Some messages are handled by delegates.
1293 if (appcache_dispatcher_->OnMessageReceived(msg) || 1288 if (appcache_dispatcher_->OnMessageReceived(msg) ||
1294 dom_storage_dispatcher_->OnMessageReceived(msg) || 1289 dom_storage_dispatcher_->OnMessageReceived(msg) ||
1295 embedded_worker_dispatcher_->OnMessageReceived(msg)) { 1290 embedded_worker_dispatcher_->OnMessageReceived(msg)) {
1296 return true; 1291 return true;
1297 } 1292 }
1298 1293
1299 bool handled = true; 1294 bool handled = true;
1300 IPC_BEGIN_MESSAGE_MAP(RenderThreadImpl, msg) 1295 IPC_BEGIN_MESSAGE_MAP(RenderThreadImpl, msg)
1296 IPC_MESSAGE_HANDLER(FrameMsg_NewFrame, OnCreateNewFrame)
1297 IPC_MESSAGE_HANDLER(FrameMsg_NewFrameProxy, OnCreateNewFrameProxy)
1301 IPC_MESSAGE_HANDLER(ViewMsg_SetZoomLevelForCurrentURL, 1298 IPC_MESSAGE_HANDLER(ViewMsg_SetZoomLevelForCurrentURL,
1302 OnSetZoomLevelForCurrentURL) 1299 OnSetZoomLevelForCurrentURL)
1303 // TODO(port): removed from render_messages_internal.h; 1300 // TODO(port): removed from render_messages_internal.h;
1304 // is there a new non-windows message I should add here? 1301 // is there a new non-windows message I should add here?
1305 IPC_MESSAGE_HANDLER(ViewMsg_New, OnCreateNewView) 1302 IPC_MESSAGE_HANDLER(ViewMsg_New, OnCreateNewView)
1306 IPC_MESSAGE_HANDLER(ViewMsg_PurgePluginListCache, OnPurgePluginListCache) 1303 IPC_MESSAGE_HANDLER(ViewMsg_PurgePluginListCache, OnPurgePluginListCache)
1307 IPC_MESSAGE_HANDLER(ViewMsg_NetworkTypeChanged, OnNetworkTypeChanged) 1304 IPC_MESSAGE_HANDLER(ViewMsg_NetworkTypeChanged, OnNetworkTypeChanged)
1308 IPC_MESSAGE_HANDLER(ViewMsg_TempCrashWithData, OnTempCrashWithData) 1305 IPC_MESSAGE_HANDLER(ViewMsg_TempCrashWithData, OnTempCrashWithData)
1309 IPC_MESSAGE_HANDLER(WorkerProcessMsg_CreateWorker, OnCreateNewSharedWorker) 1306 IPC_MESSAGE_HANDLER(WorkerProcessMsg_CreateWorker, OnCreateNewSharedWorker)
1310 IPC_MESSAGE_HANDLER(ViewMsg_TimezoneChange, OnUpdateTimezone) 1307 IPC_MESSAGE_HANDLER(ViewMsg_TimezoneChange, OnUpdateTimezone)
1311 #if defined(OS_ANDROID) 1308 #if defined(OS_ANDROID)
1312 IPC_MESSAGE_HANDLER(ViewMsg_SetWebKitSharedTimersSuspended, 1309 IPC_MESSAGE_HANDLER(ViewMsg_SetWebKitSharedTimersSuspended,
1313 OnSetWebKitSharedTimersSuspended) 1310 OnSetWebKitSharedTimersSuspended)
1314 #endif 1311 #endif
1315 #if defined(OS_MACOSX) 1312 #if defined(OS_MACOSX)
1316 IPC_MESSAGE_HANDLER(ViewMsg_UpdateScrollbarTheme, OnUpdateScrollbarTheme) 1313 IPC_MESSAGE_HANDLER(ViewMsg_UpdateScrollbarTheme, OnUpdateScrollbarTheme)
1317 #endif 1314 #endif
1318 IPC_MESSAGE_UNHANDLED(handled = false) 1315 IPC_MESSAGE_UNHANDLED(handled = false)
1319 IPC_END_MESSAGE_MAP() 1316 IPC_END_MESSAGE_MAP()
1320 return handled; 1317 return handled;
1321 } 1318 }
1322 1319
1320 void RenderThreadImpl::OnCreateNewFrame(int routing_id, int parent_routing_id) {
1321 // TODO(nasko): For now, this message is only sent for subframes, as the
Charlie Reis 2014/07/24 22:36:32 "For now" -> do we expect that to change? Why?
nasko 2014/07/25 07:13:21 Yes. Once we eliminate RenderView(Host), we need t
1322 // top level frame is created when the RenderView is created through the
1323 // ViewMsg_New IPC.
1324 CHECK(parent_routing_id != MSG_ROUTING_NONE);
1325
1326 RenderFrameImpl::CreateFrame(routing_id, parent_routing_id);
1327 }
1328
1329 void RenderThreadImpl::OnCreateNewFrameProxy(int routing_id,
1330 int parent_routing_id,
1331 int render_view_routing_id) {
1332 RenderFrameProxy::CreateFrameProxy(
1333 routing_id, parent_routing_id, render_view_routing_id);
1334 }
1335
1336 void RenderThreadImpl::OnSetZoomLevelForCurrentURL(const std::string& scheme,
1337 const std::string& host,
1338 double zoom_level) {
1339 RenderViewZoomer zoomer(scheme, host, zoom_level);
1340 RenderView::ForEach(&zoomer);
1341 }
1342
1323 void RenderThreadImpl::OnCreateNewView(const ViewMsg_New_Params& params) { 1343 void RenderThreadImpl::OnCreateNewView(const ViewMsg_New_Params& params) {
1324 EnsureWebKitInitialized(); 1344 EnsureWebKitInitialized();
1325 // When bringing in render_view, also bring in webkit's glue and jsbindings. 1345 // When bringing in render_view, also bring in webkit's glue and jsbindings.
1326 RenderViewImpl::Create(params.opener_route_id, 1346 RenderViewImpl::Create(params.opener_route_id,
1327 params.window_was_created_with_opener, 1347 params.window_was_created_with_opener,
1328 params.renderer_preferences, 1348 params.renderer_preferences,
1329 params.web_preferences, 1349 params.web_preferences,
1330 params.view_id, 1350 params.view_id,
1331 params.main_frame_routing_id, 1351 params.main_frame_routing_id,
1332 params.surface_id, 1352 params.surface_id,
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
1447 1467
1448 void RenderThreadImpl::OnTempCrashWithData(const GURL& data) { 1468 void RenderThreadImpl::OnTempCrashWithData(const GURL& data) {
1449 GetContentClient()->SetActiveURL(data); 1469 GetContentClient()->SetActiveURL(data);
1450 CHECK(false); 1470 CHECK(false);
1451 } 1471 }
1452 1472
1453 void RenderThreadImpl::OnUpdateTimezone() { 1473 void RenderThreadImpl::OnUpdateTimezone() {
1454 NotifyTimezoneChange(); 1474 NotifyTimezoneChange();
1455 } 1475 }
1456 1476
1457
1458 #if defined(OS_ANDROID) 1477 #if defined(OS_ANDROID)
1459 void RenderThreadImpl::OnSetWebKitSharedTimersSuspended(bool suspend) { 1478 void RenderThreadImpl::OnSetWebKitSharedTimersSuspended(bool suspend) {
1460 if (suspend_webkit_shared_timer_) { 1479 if (suspend_webkit_shared_timer_) {
1461 EnsureWebKitInitialized(); 1480 EnsureWebKitInitialized();
1462 if (suspend) { 1481 if (suspend) {
1463 webkit_platform_support_->SuspendSharedTimer(); 1482 webkit_platform_support_->SuspendSharedTimer();
1464 } else { 1483 } else {
1465 webkit_platform_support_->ResumeSharedTimer(); 1484 webkit_platform_support_->ResumeSharedTimer();
1466 } 1485 }
1467 webkit_shared_timer_suspended_ = suspend; 1486 webkit_shared_timer_suspended_ = suspend;
(...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after
1596 hidden_widget_count_--; 1615 hidden_widget_count_--;
1597 1616
1598 if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) { 1617 if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) {
1599 return; 1618 return;
1600 } 1619 }
1601 1620
1602 ScheduleIdleHandler(kLongIdleHandlerDelayMs); 1621 ScheduleIdleHandler(kLongIdleHandlerDelayMs);
1603 } 1622 }
1604 1623
1605 } // namespace content 1624 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698