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 "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/files/file_path.h" | 8 #include "base/files/file_path.h" |
9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
43 #include "content/renderer/device_sensors/device_orientation_event_pump.h" | 43 #include "content/renderer/device_sensors/device_orientation_event_pump.h" |
44 #include "content/renderer/dom_storage/webstoragenamespace_impl.h" | 44 #include "content/renderer/dom_storage/webstoragenamespace_impl.h" |
45 #include "content/renderer/gamepad_shared_memory_reader.h" | 45 #include "content/renderer/gamepad_shared_memory_reader.h" |
46 #include "content/renderer/media/audio_decoder.h" | 46 #include "content/renderer/media/audio_decoder.h" |
47 #include "content/renderer/media/crypto/key_systems.h" | 47 #include "content/renderer/media/crypto/key_systems.h" |
48 #include "content/renderer/media/renderer_webaudiodevice_impl.h" | 48 #include "content/renderer/media/renderer_webaudiodevice_impl.h" |
49 #include "content/renderer/media/renderer_webmidiaccessor_impl.h" | 49 #include "content/renderer/media/renderer_webmidiaccessor_impl.h" |
50 #include "content/renderer/media/webcontentdecryptionmodule_impl.h" | 50 #include "content/renderer/media/webcontentdecryptionmodule_impl.h" |
51 #include "content/renderer/render_thread_impl.h" | 51 #include "content/renderer/render_thread_impl.h" |
52 #include "content/renderer/renderer_clipboard_client.h" | 52 #include "content/renderer/renderer_clipboard_client.h" |
| 53 #include "content/renderer/scheduler/task_queue_manager.h" |
53 #include "content/renderer/screen_orientation/screen_orientation_observer.h" | 54 #include "content/renderer/screen_orientation/screen_orientation_observer.h" |
54 #include "content/renderer/webclipboard_impl.h" | 55 #include "content/renderer/webclipboard_impl.h" |
55 #include "content/renderer/webgraphicscontext3d_provider_impl.h" | 56 #include "content/renderer/webgraphicscontext3d_provider_impl.h" |
56 #include "content/renderer/webpublicsuffixlist_impl.h" | 57 #include "content/renderer/webpublicsuffixlist_impl.h" |
57 #include "gpu/config/gpu_info.h" | 58 #include "gpu/config/gpu_info.h" |
58 #include "ipc/ipc_sync_message_filter.h" | 59 #include "ipc/ipc_sync_message_filter.h" |
59 #include "media/audio/audio_output_device.h" | 60 #include "media/audio/audio_output_device.h" |
60 #include "media/base/audio_hardware_config.h" | 61 #include "media/base/audio_hardware_config.h" |
61 #include "media/filters/stream_parser_factory.h" | 62 #include "media/filters/stream_parser_factory.h" |
62 #include "net/base/mime_util.h" | 63 #include "net/base/mime_util.h" |
(...skipping 152 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
215 // here. | 216 // here. |
216 base::Lock unicode_font_families_mutex_; | 217 base::Lock unicode_font_families_mutex_; |
217 std::map<int32_t, blink::WebFallbackFont> unicode_font_families_; | 218 std::map<int32_t, blink::WebFallbackFont> unicode_font_families_; |
218 #endif | 219 #endif |
219 }; | 220 }; |
220 #endif // defined(OS_ANDROID) | 221 #endif // defined(OS_ANDROID) |
221 | 222 |
222 //------------------------------------------------------------------------------ | 223 //------------------------------------------------------------------------------ |
223 | 224 |
224 RendererBlinkPlatformImpl::RendererBlinkPlatformImpl() | 225 RendererBlinkPlatformImpl::RendererBlinkPlatformImpl() |
225 : clipboard_client_(new RendererClipboardClient), | 226 : task_queue_manager_( |
| 227 new TaskQueueManager(base::MessageLoopProxy::current())), |
| 228 clipboard_client_(new RendererClipboardClient), |
226 clipboard_(new WebClipboardImpl(clipboard_client_.get())), | 229 clipboard_(new WebClipboardImpl(clipboard_client_.get())), |
227 mime_registry_(new RendererBlinkPlatformImpl::MimeRegistry), | 230 mime_registry_(new RendererBlinkPlatformImpl::MimeRegistry), |
228 sudden_termination_disables_(0), | 231 sudden_termination_disables_(0), |
229 plugin_refresh_allowed_(true), | 232 plugin_refresh_allowed_(true), |
230 child_thread_loop_(base::MessageLoopProxy::current()), | 233 child_thread_loop_(base::MessageLoopProxy::current()), |
231 web_scrollbar_behavior_(new WebScrollbarBehaviorImpl) { | 234 web_scrollbar_behavior_(new WebScrollbarBehaviorImpl) { |
232 if (g_sandbox_enabled && sandboxEnabled()) { | 235 if (g_sandbox_enabled && sandboxEnabled()) { |
233 sandbox_support_.reset(new RendererBlinkPlatformImpl::SandboxSupport); | 236 sandbox_support_.reset(new RendererBlinkPlatformImpl::SandboxSupport); |
234 } else { | 237 } else { |
235 DVLOG(1) << "Disabling sandbox support for testing."; | 238 DVLOG(1) << "Disabling sandbox support for testing."; |
(...skipping 10 matching lines...) Expand all Loading... |
246 new WebDatabaseObserverImpl(sync_message_filter_.get())); | 249 new WebDatabaseObserverImpl(sync_message_filter_.get())); |
247 } | 250 } |
248 } | 251 } |
249 | 252 |
250 RendererBlinkPlatformImpl::~RendererBlinkPlatformImpl() { | 253 RendererBlinkPlatformImpl::~RendererBlinkPlatformImpl() { |
251 WebFileSystemImpl::DeleteThreadSpecificInstance(); | 254 WebFileSystemImpl::DeleteThreadSpecificInstance(); |
252 } | 255 } |
253 | 256 |
254 //------------------------------------------------------------------------------ | 257 //------------------------------------------------------------------------------ |
255 | 258 |
| 259 void RendererBlinkPlatformImpl::callOnMainThread(void (*func)(void*), |
| 260 void* context) { |
| 261 task_queue_manager_->TaskRunnerForQueue(TaskQueueManager::kDefaultTaskQueue) |
| 262 ->PostTask(FROM_HERE, base::Bind(func, context)); |
| 263 } |
| 264 |
256 blink::WebClipboard* RendererBlinkPlatformImpl::clipboard() { | 265 blink::WebClipboard* RendererBlinkPlatformImpl::clipboard() { |
257 blink::WebClipboard* clipboard = | 266 blink::WebClipboard* clipboard = |
258 GetContentClient()->renderer()->OverrideWebClipboard(); | 267 GetContentClient()->renderer()->OverrideWebClipboard(); |
259 if (clipboard) | 268 if (clipboard) |
260 return clipboard; | 269 return clipboard; |
261 return clipboard_.get(); | 270 return clipboard_.get(); |
262 } | 271 } |
263 | 272 |
264 blink::WebMimeRegistry* RendererBlinkPlatformImpl::mimeRegistry() { | 273 blink::WebMimeRegistry* RendererBlinkPlatformImpl::mimeRegistry() { |
265 return mime_registry_.get(); | 274 return mime_registry_.get(); |
(...skipping 905 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1171 void RendererBlinkPlatformImpl::MockBatteryStatusChangedForTesting( | 1180 void RendererBlinkPlatformImpl::MockBatteryStatusChangedForTesting( |
1172 const blink::WebBatteryStatus& status) { | 1181 const blink::WebBatteryStatus& status) { |
1173 PlatformEventObserverBase* observer = | 1182 PlatformEventObserverBase* observer = |
1174 platform_event_observers_.Lookup(blink::WebPlatformEventBattery); | 1183 platform_event_observers_.Lookup(blink::WebPlatformEventBattery); |
1175 if (!observer) | 1184 if (!observer) |
1176 return; | 1185 return; |
1177 observer->SendFakeDataForTesting((void*)&status); | 1186 observer->SendFakeDataForTesting((void*)&status); |
1178 } | 1187 } |
1179 | 1188 |
1180 } // namespace content | 1189 } // namespace content |
OLD | NEW |