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 "chrome/renderer/plugins/chrome_plugin_placeholder.h" | 5 #include "chrome/renderer/plugins/chrome_plugin_placeholder.h" |
6 | 6 |
7 #include "base/strings/string_number_conversions.h" | 7 #include "base/strings/string_number_conversions.h" |
8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
9 #include "base/values.h" | 9 #include "base/values.h" |
10 #include "chrome/common/prerender_messages.h" | 10 #include "chrome/common/prerender_messages.h" |
11 #include "chrome/common/render_messages.h" | 11 #include "chrome/common/render_messages.h" |
12 #include "chrome/grit/generated_resources.h" | 12 #include "chrome/grit/generated_resources.h" |
13 #include "chrome/grit/renderer_resources.h" | 13 #include "chrome/grit/renderer_resources.h" |
14 #include "chrome/renderer/chrome_content_renderer_client.h" | 14 #include "chrome/renderer/chrome_content_renderer_client.h" |
15 #include "chrome/renderer/custom_menu_commands.h" | 15 #include "chrome/renderer/custom_menu_commands.h" |
| 16 #include "chrome/renderer/plugins/plugin_preroller.h" |
16 #include "chrome/renderer/plugins/plugin_uma.h" | 17 #include "chrome/renderer/plugins/plugin_uma.h" |
17 #include "components/content_settings/content/common/content_settings_messages.h
" | 18 #include "components/content_settings/content/common/content_settings_messages.h
" |
18 #include "content/app/strings/grit/content_strings.h" | 19 #include "content/app/strings/grit/content_strings.h" |
19 #include "content/public/common/context_menu_params.h" | 20 #include "content/public/common/context_menu_params.h" |
20 #include "content/public/renderer/render_frame.h" | 21 #include "content/public/renderer/render_frame.h" |
21 #include "content/public/renderer/render_thread.h" | 22 #include "content/public/renderer/render_thread.h" |
22 #include "gin/object_template_builder.h" | 23 #include "gin/object_template_builder.h" |
23 #include "third_party/WebKit/public/web/WebDocument.h" | 24 #include "third_party/WebKit/public/web/WebDocument.h" |
24 #include "third_party/WebKit/public/web/WebInputEvent.h" | 25 #include "third_party/WebKit/public/web/WebInputEvent.h" |
25 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 26 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
(...skipping 333 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
359 params.custom_items.push_back(hide_item); | 360 params.custom_items.push_back(hide_item); |
360 | 361 |
361 params.x = event.windowX; | 362 params.x = event.windowX; |
362 params.y = event.windowY; | 363 params.y = event.windowY; |
363 | 364 |
364 context_menu_request_id_ = render_frame()->ShowContextMenu(this, params); | 365 context_menu_request_id_ = render_frame()->ShowContextMenu(this, params); |
365 g_last_active_menu = this; | 366 g_last_active_menu = this; |
366 #endif // OS_ANDROID | 367 #endif // OS_ANDROID |
367 } | 368 } |
368 | 369 |
| 370 blink::WebPlugin* ChromePluginPlaceholder::CreatePlugin() { |
| 371 scoped_ptr<content::PluginInstanceThrottler> throttler; |
| 372 #if defined(ENABLE_PLUGINS) |
| 373 // If the plugin has already been marked essential in its placeholder form, |
| 374 // we shouldn't create a new throttler and start the process all over again. |
| 375 if (power_saver_enabled()) { |
| 376 throttler = content::PluginInstanceThrottler::Create(); |
| 377 // PluginPreroller manages its own lifetime. |
| 378 new PluginPreroller(render_frame(), GetFrame(), GetPluginParams(), |
| 379 GetPluginInfo(), GetIdentifier(), title_, |
| 380 l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED, title_), |
| 381 throttler.get()); |
| 382 } |
| 383 #endif |
| 384 return render_frame()->CreatePlugin(GetFrame(), GetPluginInfo(), |
| 385 GetPluginParams(), throttler.Pass()); |
| 386 } |
| 387 |
369 gin::ObjectTemplateBuilder ChromePluginPlaceholder::GetObjectTemplateBuilder( | 388 gin::ObjectTemplateBuilder ChromePluginPlaceholder::GetObjectTemplateBuilder( |
370 v8::Isolate* isolate) { | 389 v8::Isolate* isolate) { |
371 return LoadablePluginPlaceholder::GetObjectTemplateBuilder(isolate).SetMethod( | 390 return LoadablePluginPlaceholder::GetObjectTemplateBuilder(isolate).SetMethod( |
372 "openAboutPlugins", &ChromePluginPlaceholder::OpenAboutPluginsCallback); | 391 "openAboutPlugins", &ChromePluginPlaceholder::OpenAboutPluginsCallback); |
373 } | 392 } |
OLD | NEW |