Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 |
| OLD | NEW |