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/renderer_blink_platform_impl.h" | 5 #include "content/renderer/renderer_blink_platform_impl.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 35 #include "content/child/storage_util.h" | 35 #include "content/child/storage_util.h" |
| 36 #include "content/child/thread_safe_sender.h" | 36 #include "content/child/thread_safe_sender.h" |
| 37 #include "content/child/web_database_observer_impl.h" | 37 #include "content/child/web_database_observer_impl.h" |
| 38 #include "content/child/web_url_loader_impl.h" | 38 #include "content/child/web_url_loader_impl.h" |
| 39 #include "content/child/webfileutilities_impl.h" | 39 #include "content/child/webfileutilities_impl.h" |
| 40 #include "content/child/webmessageportchannel_impl.h" | 40 #include "content/child/webmessageportchannel_impl.h" |
| 41 #include "content/common/file_utilities_messages.h" | 41 #include "content/common/file_utilities_messages.h" |
| 42 #include "content/common/frame_messages.h" | 42 #include "content/common/frame_messages.h" |
| 43 #include "content/common/render_process_messages.h" | 43 #include "content/common/render_process_messages.h" |
| 44 #include "content/public/common/content_switches.h" | 44 #include "content/public/common/content_switches.h" |
| 45 #include "content/public/common/service_manager_connection.h" | |
| 45 #include "content/public/common/webplugininfo.h" | 46 #include "content/public/common/webplugininfo.h" |
| 46 #include "content/public/renderer/content_renderer_client.h" | 47 #include "content/public/renderer/content_renderer_client.h" |
| 47 #include "content/public/renderer/media_stream_utils.h" | 48 #include "content/public/renderer/media_stream_utils.h" |
| 48 #include "content/public/renderer/render_frame.h" | 49 #include "content/public/renderer/render_frame.h" |
| 49 #include "content/renderer/cache_storage/webserviceworkercachestorage_impl.h" | 50 #include "content/renderer/cache_storage/webserviceworkercachestorage_impl.h" |
| 50 #include "content/renderer/device_sensors/device_light_event_pump.h" | 51 #include "content/renderer/device_sensors/device_light_event_pump.h" |
| 51 #include "content/renderer/device_sensors/device_motion_event_pump.h" | 52 #include "content/renderer/device_sensors/device_motion_event_pump.h" |
| 52 #include "content/renderer/device_sensors/device_orientation_event_pump.h" | 53 #include "content/renderer/device_sensors/device_orientation_event_pump.h" |
| 53 #include "content/renderer/dom_storage/local_storage_cached_areas.h" | 54 #include "content/renderer/dom_storage/local_storage_cached_areas.h" |
| 54 #include "content/renderer/dom_storage/local_storage_namespace.h" | 55 #include "content/renderer/dom_storage/local_storage_namespace.h" |
| 55 #include "content/renderer/dom_storage/webstoragenamespace_impl.h" | 56 #include "content/renderer/dom_storage/webstoragenamespace_impl.h" |
| 56 #include "content/renderer/gamepad_shared_memory_reader.h" | 57 #include "content/renderer/gamepad_shared_memory_reader.h" |
| 57 #include "content/renderer/image_capture/image_capture_frame_grabber.h" | 58 #include "content/renderer/image_capture/image_capture_frame_grabber.h" |
| 58 #include "content/renderer/media/audio_decoder.h" | 59 #include "content/renderer/media/audio_decoder.h" |
| 59 #include "content/renderer/media/audio_device_factory.h" | 60 #include "content/renderer/media/audio_device_factory.h" |
| 60 #include "content/renderer/media/renderer_webaudiodevice_impl.h" | 61 #include "content/renderer/media/renderer_webaudiodevice_impl.h" |
| 61 #include "content/renderer/media/renderer_webmidiaccessor_impl.h" | 62 #include "content/renderer/media/renderer_webmidiaccessor_impl.h" |
| 62 #include "content/renderer/media_capture_from_element/canvas_capture_handler.h" | 63 #include "content/renderer/media_capture_from_element/canvas_capture_handler.h" |
| 63 #include "content/renderer/media_capture_from_element/html_audio_element_capture r_source.h" | 64 #include "content/renderer/media_capture_from_element/html_audio_element_capture r_source.h" |
| 64 #include "content/renderer/media_capture_from_element/html_video_element_capture r_source.h" | 65 #include "content/renderer/media_capture_from_element/html_video_element_capture r_source.h" |
| 65 #include "content/renderer/media_recorder/media_recorder_handler.h" | 66 #include "content/renderer/media_recorder/media_recorder_handler.h" |
| 67 #include "content/renderer/mojo/blink_connector_impl.h" | |
| 66 #include "content/renderer/mojo/blink_interface_provider_impl.h" | 68 #include "content/renderer/mojo/blink_interface_provider_impl.h" |
| 67 #include "content/renderer/render_thread_impl.h" | 69 #include "content/renderer/render_thread_impl.h" |
| 68 #include "content/renderer/renderer_clipboard_delegate.h" | 70 #include "content/renderer/renderer_clipboard_delegate.h" |
| 69 #include "content/renderer/webclipboard_impl.h" | 71 #include "content/renderer/webclipboard_impl.h" |
| 70 #include "content/renderer/webgraphicscontext3d_provider_impl.h" | 72 #include "content/renderer/webgraphicscontext3d_provider_impl.h" |
| 71 #include "content/renderer/webpublicsuffixlist_impl.h" | 73 #include "content/renderer/webpublicsuffixlist_impl.h" |
| 72 #include "gpu/command_buffer/client/gles2_interface.h" | 74 #include "gpu/command_buffer/client/gles2_interface.h" |
| 73 #include "gpu/config/gpu_info.h" | 75 #include "gpu/config/gpu_info.h" |
| 74 #include "gpu/ipc/client/gpu_channel_host.h" | 76 #include "gpu/ipc/client/gpu_channel_host.h" |
| 75 #include "gpu/ipc/common/gpu_stream_constants.h" | 77 #include "gpu/ipc/common/gpu_stream_constants.h" |
| 76 #include "ipc/ipc_sync_message_filter.h" | 78 #include "ipc/ipc_sync_message_filter.h" |
| 77 #include "media/audio/audio_output_device.h" | 79 #include "media/audio/audio_output_device.h" |
| 78 #include "media/blink/webcontentdecryptionmodule_impl.h" | 80 #include "media/blink/webcontentdecryptionmodule_impl.h" |
| 79 #include "media/filters/stream_parser_factory.h" | 81 #include "media/filters/stream_parser_factory.h" |
| 80 #include "ppapi/features/features.h" | 82 #include "ppapi/features/features.h" |
| 83 #include "services/service_manager/public/cpp/connector.h" | |
| 81 #include "services/service_manager/public/cpp/interface_provider.h" | 84 #include "services/service_manager/public/cpp/interface_provider.h" |
| 82 #include "services/ui/public/cpp/gpu/context_provider_command_buffer.h" | 85 #include "services/ui/public/cpp/gpu/context_provider_command_buffer.h" |
| 83 #include "storage/common/database/database_identifier.h" | 86 #include "storage/common/database/database_identifier.h" |
| 84 #include "storage/common/quota/quota_types.h" | 87 #include "storage/common/quota/quota_types.h" |
| 85 #include "third_party/WebKit/public/platform/BlameContext.h" | 88 #include "third_party/WebKit/public/platform/BlameContext.h" |
| 86 #include "third_party/WebKit/public/platform/FilePathConversion.h" | 89 #include "third_party/WebKit/public/platform/FilePathConversion.h" |
| 87 #include "third_party/WebKit/public/platform/URLConversion.h" | 90 #include "third_party/WebKit/public/platform/URLConversion.h" |
| 88 #include "third_party/WebKit/public/platform/WebAudioLatencyHint.h" | 91 #include "third_party/WebKit/public/platform/WebAudioLatencyHint.h" |
| 89 #include "third_party/WebKit/public/platform/WebBlobRegistry.h" | 92 #include "third_party/WebKit/public/platform/WebBlobRegistry.h" |
| 90 #include "third_party/WebKit/public/platform/WebDeviceLightListener.h" | 93 #include "third_party/WebKit/public/platform/WebDeviceLightListener.h" |
| (...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 242 : BlinkPlatformImpl(renderer_scheduler->DefaultTaskRunner()), | 245 : BlinkPlatformImpl(renderer_scheduler->DefaultTaskRunner()), |
| 243 main_thread_(renderer_scheduler->CreateMainThread()), | 246 main_thread_(renderer_scheduler->CreateMainThread()), |
| 244 clipboard_delegate_(new RendererClipboardDelegate), | 247 clipboard_delegate_(new RendererClipboardDelegate), |
| 245 clipboard_(new WebClipboardImpl(clipboard_delegate_.get())), | 248 clipboard_(new WebClipboardImpl(clipboard_delegate_.get())), |
| 246 sudden_termination_disables_(0), | 249 sudden_termination_disables_(0), |
| 247 plugin_refresh_allowed_(true), | 250 plugin_refresh_allowed_(true), |
| 248 default_task_runner_(renderer_scheduler->DefaultTaskRunner()), | 251 default_task_runner_(renderer_scheduler->DefaultTaskRunner()), |
| 249 loading_task_runner_(renderer_scheduler->LoadingTaskRunner()), | 252 loading_task_runner_(renderer_scheduler->LoadingTaskRunner()), |
| 250 web_scrollbar_behavior_(new WebScrollbarBehaviorImpl), | 253 web_scrollbar_behavior_(new WebScrollbarBehaviorImpl), |
| 251 renderer_scheduler_(renderer_scheduler), | 254 renderer_scheduler_(renderer_scheduler), |
| 255 blink_connector_(new BlinkConnectorImpl(nullptr)), | |
| 252 blink_interface_provider_( | 256 blink_interface_provider_( |
| 253 new BlinkInterfaceProviderImpl(remote_interfaces)) { | 257 new BlinkInterfaceProviderImpl(remote_interfaces)) { |
| 254 #if !defined(OS_ANDROID) && !defined(OS_WIN) | 258 #if !defined(OS_ANDROID) && !defined(OS_WIN) |
| 255 if (g_sandbox_enabled && sandboxEnabled()) { | 259 if (g_sandbox_enabled && sandboxEnabled()) { |
| 256 sandbox_support_.reset(new RendererBlinkPlatformImpl::SandboxSupport); | 260 sandbox_support_.reset(new RendererBlinkPlatformImpl::SandboxSupport); |
| 257 } else { | 261 } else { |
| 258 DVLOG(1) << "Disabling sandbox support for testing."; | 262 DVLOG(1) << "Disabling sandbox support for testing."; |
| 259 } | 263 } |
| 260 #endif | 264 #endif |
| 261 | 265 |
| 262 // RenderThread may not exist in some tests. | 266 // RenderThread may not exist in some tests. |
| 263 if (RenderThreadImpl::current()) { | 267 if (RenderThreadImpl::current()) { |
|
dcheng
2017/03/21 18:56:18
Ah... bah. This issue again...
I guess you can ig
| |
| 268 blink_connector_->SetConnector(RenderThreadImpl::current() | |
| 269 ->GetServiceManagerConnection() | |
| 270 ->GetConnector() | |
| 271 ->Clone()); | |
| 264 sync_message_filter_ = RenderThreadImpl::current()->sync_message_filter(); | 272 sync_message_filter_ = RenderThreadImpl::current()->sync_message_filter(); |
| 265 thread_safe_sender_ = RenderThreadImpl::current()->thread_safe_sender(); | 273 thread_safe_sender_ = RenderThreadImpl::current()->thread_safe_sender(); |
| 266 quota_message_filter_ = RenderThreadImpl::current()->quota_message_filter(); | 274 quota_message_filter_ = RenderThreadImpl::current()->quota_message_filter(); |
| 267 shared_bitmap_manager_ = | 275 shared_bitmap_manager_ = |
| 268 RenderThreadImpl::current()->shared_bitmap_manager(); | 276 RenderThreadImpl::current()->shared_bitmap_manager(); |
| 269 blob_registry_.reset(new WebBlobRegistryImpl( | 277 blob_registry_.reset(new WebBlobRegistryImpl( |
| 270 RenderThreadImpl::current()->GetIOTaskRunner().get(), | 278 RenderThreadImpl::current()->GetIOTaskRunner().get(), |
| 271 base::ThreadTaskRunnerHandle::Get(), thread_safe_sender_.get())); | 279 base::ThreadTaskRunnerHandle::Get(), thread_safe_sender_.get())); |
| 272 web_idb_factory_.reset(new WebIDBFactoryImpl( | 280 web_idb_factory_.reset(new WebIDBFactoryImpl( |
| 273 sync_message_filter_, | 281 sync_message_filter_, |
| (...skipping 868 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1142 } | 1150 } |
| 1143 | 1151 |
| 1144 void RendererBlinkPlatformImpl::SetPlatformEventObserverForTesting( | 1152 void RendererBlinkPlatformImpl::SetPlatformEventObserverForTesting( |
| 1145 blink::WebPlatformEventType type, | 1153 blink::WebPlatformEventType type, |
| 1146 std::unique_ptr<PlatformEventObserverBase> observer) { | 1154 std::unique_ptr<PlatformEventObserverBase> observer) { |
| 1147 if (platform_event_observers_.Lookup(type)) | 1155 if (platform_event_observers_.Lookup(type)) |
| 1148 platform_event_observers_.Remove(type); | 1156 platform_event_observers_.Remove(type); |
| 1149 platform_event_observers_.AddWithID(std::move(observer), type); | 1157 platform_event_observers_.AddWithID(std::move(observer), type); |
| 1150 } | 1158 } |
| 1151 | 1159 |
| 1160 blink::Connector* RendererBlinkPlatformImpl::connector() { | |
| 1161 return blink_connector_.get(); | |
| 1162 } | |
| 1163 | |
| 1152 blink::InterfaceProvider* RendererBlinkPlatformImpl::interfaceProvider() { | 1164 blink::InterfaceProvider* RendererBlinkPlatformImpl::interfaceProvider() { |
| 1153 return blink_interface_provider_.get(); | 1165 return blink_interface_provider_.get(); |
| 1154 } | 1166 } |
| 1155 | 1167 |
| 1156 void RendererBlinkPlatformImpl::startListening( | 1168 void RendererBlinkPlatformImpl::startListening( |
| 1157 blink::WebPlatformEventType type, | 1169 blink::WebPlatformEventType type, |
| 1158 blink::WebPlatformEventListener* listener) { | 1170 blink::WebPlatformEventListener* listener) { |
| 1159 PlatformEventObserverBase* observer = platform_event_observers_.Lookup(type); | 1171 PlatformEventObserverBase* observer = platform_event_observers_.Lookup(type); |
| 1160 if (!observer) { | 1172 if (!observer) { |
| 1161 std::unique_ptr<PlatformEventObserverBase> new_observer = | 1173 std::unique_ptr<PlatformEventObserverBase> new_observer = |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1256 //------------------------------------------------------------------------------ | 1268 //------------------------------------------------------------------------------ |
| 1257 void RendererBlinkPlatformImpl::requestPurgeMemory() { | 1269 void RendererBlinkPlatformImpl::requestPurgeMemory() { |
| 1258 // TODO(tasak|bashi): We should use ChildMemoryCoordinator here, but | 1270 // TODO(tasak|bashi): We should use ChildMemoryCoordinator here, but |
| 1259 // ChildMemoryCoordinator isn't always available as it's only initialized | 1271 // ChildMemoryCoordinator isn't always available as it's only initialized |
| 1260 // when kMemoryCoordinatorV0 is enabled. | 1272 // when kMemoryCoordinatorV0 is enabled. |
| 1261 // Use ChildMemoryCoordinator when memory coordinator is always enabled. | 1273 // Use ChildMemoryCoordinator when memory coordinator is always enabled. |
| 1262 base::MemoryCoordinatorClientRegistry::GetInstance()->PurgeMemory(); | 1274 base::MemoryCoordinatorClientRegistry::GetInstance()->PurgeMemory(); |
| 1263 } | 1275 } |
| 1264 | 1276 |
| 1265 } // namespace content | 1277 } // namespace content |
| OLD | NEW |