diff options
-rw-r--r-- | chrome/renderer/plugins/DEPS | 1 | ||||
-rw-r--r-- | chrome/renderer/plugins/chrome_plugin_placeholder.cc | 30 | ||||
-rw-r--r-- | chrome/renderer/plugins/chrome_plugin_placeholder.h | 8 | ||||
-rw-r--r-- | components/plugins.gypi | 2 | ||||
-rw-r--r-- | components/plugins/renderer/DEPS | 2 | ||||
-rw-r--r-- | components/plugins/renderer/mobile_youtube_plugin.cc | 29 | ||||
-rw-r--r-- | components/plugins/renderer/mobile_youtube_plugin.h | 9 | ||||
-rw-r--r-- | components/plugins/renderer/plugin_placeholder.cc | 44 | ||||
-rw-r--r-- | components/plugins/renderer/plugin_placeholder.h | 27 | ||||
-rw-r--r-- | components/plugins/renderer/webview_plugin.cc | 4 | ||||
-rw-r--r-- | components/plugins/renderer/webview_plugin.h | 10 |
11 files changed, 98 insertions, 68 deletions
diff --git a/chrome/renderer/plugins/DEPS b/chrome/renderer/plugins/DEPS index 9883c71..3929850 100644 --- a/chrome/renderer/plugins/DEPS +++ b/chrome/renderer/plugins/DEPS @@ -1,3 +1,4 @@ include_rules = [ + "+gin", "+third_party/widevine", ] diff --git a/chrome/renderer/plugins/chrome_plugin_placeholder.cc b/chrome/renderer/plugins/chrome_plugin_placeholder.cc index 899087a..d6631e6 100644 --- a/chrome/renderer/plugins/chrome_plugin_placeholder.cc +++ b/chrome/renderer/plugins/chrome_plugin_placeholder.cc @@ -14,12 +14,15 @@ #include "content/public/common/context_menu_params.h" #include "content/public/renderer/render_frame.h" #include "content/public/renderer/render_thread.h" +#include "gin/handle.h" +#include "gin/object_template_builder.h" #include "grit/generated_resources.h" #include "grit/renderer_resources.h" #include "grit/webkit_strings.h" #include "third_party/WebKit/public/web/WebDocument.h" #include "third_party/WebKit/public/web/WebFrame.h" #include "third_party/WebKit/public/web/WebInputEvent.h" +#include "third_party/WebKit/public/web/WebKit.h" #include "third_party/WebKit/public/web/WebScriptSource.h" #include "ui/base/l10n/l10n_util.h" #include "ui/base/resource/resource_bundle.h" @@ -36,8 +39,6 @@ using blink::WebNode; using blink::WebPlugin; using blink::WebPluginContainer; using blink::WebPluginParams; -using webkit_glue::CppArgumentList; -using webkit_glue::CppVariant; namespace { const plugins::PluginPlaceholder* g_last_active_menu = NULL; @@ -218,9 +219,7 @@ void ChromePluginPlaceholder::OnLoadBlockedPlugins( plugins::PluginPlaceholder::OnLoadBlockedPlugins(identifier); } -void ChromePluginPlaceholder::OpenAboutPluginsCallback( - const CppArgumentList& args, - CppVariant* result) { +void ChromePluginPlaceholder::OpenAboutPluginsCallback() { RenderThread::Get()->Send( new ChromeViewHostMsg_OpenAboutPlugins(routing_id())); } @@ -267,7 +266,7 @@ void ChromePluginPlaceholder::OnCancelledDownloadingPlugin() { #endif // defined(ENABLE_PLUGIN_INSTALLATION) void ChromePluginPlaceholder::PluginListChanged() { - if (!GetFrame()) + if (!GetFrame() || !plugin()) return; WebDocument document = GetFrame()->top()->document(); if (document.isNull()) @@ -354,8 +353,19 @@ void ChromePluginPlaceholder::ShowContextMenu(const WebMouseEvent& event) { } void ChromePluginPlaceholder::BindWebFrame(blink::WebFrame* frame) { - plugins::PluginPlaceholder::BindWebFrame(frame); - BindCallback("openAboutPlugins", - base::Bind(&ChromePluginPlaceholder::OpenAboutPluginsCallback, - base::Unretained(this))); + v8::Isolate* isolate = blink::mainThreadIsolate(); + v8::HandleScope handle_scope(isolate); + v8::Handle<v8::Context> context = frame->mainWorldScriptContext(); + DCHECK(!context.IsEmpty()); + + v8::Context::Scope context_scope(context); + v8::Handle<v8::Object> global = context->Global(); + global->Set(gin::StringToV8(isolate, "plugin"), + gin::CreateHandle(isolate, this).ToV8()); +} + +gin::ObjectTemplateBuilder ChromePluginPlaceholder::GetObjectTemplateBuilder( + v8::Isolate* isolate) { + return PluginPlaceholder::GetObjectTemplateBuilder(isolate).SetMethod( + "openAboutPlugins", &ChromePluginPlaceholder::OpenAboutPluginsCallback); } diff --git a/chrome/renderer/plugins/chrome_plugin_placeholder.h b/chrome/renderer/plugins/chrome_plugin_placeholder.h index 6686920..d7d1d81 100644 --- a/chrome/renderer/plugins/chrome_plugin_placeholder.h +++ b/chrome/renderer/plugins/chrome_plugin_placeholder.h @@ -52,6 +52,10 @@ class ChromePluginPlaceholder : public plugins::PluginPlaceholder, // WebViewPlugin::Delegate (via PluginPlaceholder) method virtual void BindWebFrame(blink::WebFrame* frame) OVERRIDE; + // gin::Wrappable (via PluginPlaceholder) method + virtual gin::ObjectTemplateBuilder GetObjectTemplateBuilder( + v8::Isolate* isolate) OVERRIDE; + // content::RenderViewObserver (via PluginPlaceholder) override: virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE; @@ -66,9 +70,7 @@ class ChromePluginPlaceholder : public plugins::PluginPlaceholder, virtual void OnMenuClosed(int request_id) OVERRIDE; // Javascript callback opens chrome://plugins in a new tab. - // Arguments are required by the caller, but not used. - void OpenAboutPluginsCallback(const webkit_glue::CppArgumentList& args, - webkit_glue::CppVariant* result); + void OpenAboutPluginsCallback(); void OnLoadBlockedPlugins(const std::string& identifier); void OnSetIsPrerendering(bool is_prerendering); diff --git a/components/plugins.gypi b/components/plugins.gypi index 8ef3ea0..e7b00ec 100644 --- a/components/plugins.gypi +++ b/components/plugins.gypi @@ -11,9 +11,11 @@ 'target_name': 'plugins_renderer', 'type': 'static_library', 'dependencies': [ + '../gin/gin.gyp:gin', '../skia/skia.gyp:skia', '../third_party/re2/re2.gyp:re2', '../third_party/WebKit/public/blink.gyp:blink', + '../v8/tools/gyp/v8.gyp:v8', ], 'include_dirs': [ '..', diff --git a/components/plugins/renderer/DEPS b/components/plugins/renderer/DEPS index 088d9e6..e86eecb 100644 --- a/components/plugins/renderer/DEPS +++ b/components/plugins/renderer/DEPS @@ -1,4 +1,5 @@ include_rules = [ + "+gin", "+net", "+content/public/renderer", @@ -8,6 +9,5 @@ include_rules = [ "+third_party/re2", "+skia", "+webkit/common", - "+webkit/renderer", "+ui/base/webui", ] diff --git a/components/plugins/renderer/mobile_youtube_plugin.cc b/components/plugins/renderer/mobile_youtube_plugin.cc index dd4688a..0fc3d4a7 100644 --- a/components/plugins/renderer/mobile_youtube_plugin.cc +++ b/components/plugins/renderer/mobile_youtube_plugin.cc @@ -11,7 +11,10 @@ #include "base/values.h" #include "content/public/common/content_constants.h" #include "content/public/renderer/render_frame.h" +#include "gin/handle.h" +#include "gin/object_template_builder.h" #include "third_party/WebKit/public/web/WebFrame.h" +#include "third_party/WebKit/public/web/WebKit.h" #include "ui/base/webui/jstemplate_builder.h" using blink::WebFrame; @@ -81,6 +84,8 @@ MobileYouTubePlugin::MobileYouTubePlugin(content::RenderFrame* render_frame, HtmlData(params, template_html), placeholderDataUrl) {} +MobileYouTubePlugin::~MobileYouTubePlugin() {} + // static bool MobileYouTubePlugin::IsYouTubeURL(const GURL& url, const std::string& mime_type) { @@ -92,9 +97,7 @@ bool MobileYouTubePlugin::IsYouTubeURL(const GURL& url, LowerCaseEqualsASCII(mime_type, content::kFlashPluginSwfMimeType); } -void MobileYouTubePlugin::OpenYoutubeUrlCallback( - const webkit_glue::CppArgumentList& args, - webkit_glue::CppVariant* result) { +void MobileYouTubePlugin::OpenYoutubeUrlCallback() { std::string youtube("vnd.youtube:"); GURL url(youtube.append(GetYoutubeVideoId(GetPluginParams()))); WebURLRequest request; @@ -103,11 +106,23 @@ void MobileYouTubePlugin::OpenYoutubeUrlCallback( render_frame()->LoadURLExternally( GetFrame(), request, blink::WebNavigationPolicyNewForegroundTab); } + void MobileYouTubePlugin::BindWebFrame(WebFrame* frame) { - PluginPlaceholder::BindWebFrame(frame); - BindCallback("openYoutubeURL", - base::Bind(&MobileYouTubePlugin::OpenYoutubeUrlCallback, - base::Unretained(this))); + v8::Isolate* isolate = blink::mainThreadIsolate(); + v8::HandleScope handle_scope(isolate); + v8::Handle<v8::Context> context = frame->mainWorldScriptContext(); + DCHECK(!context.IsEmpty()); + + v8::Context::Scope context_scope(context); + v8::Handle<v8::Object> global = context->Global(); + global->Set(gin::StringToV8(isolate, "plugin"), + gin::CreateHandle(isolate, this).ToV8()); +} + +gin::ObjectTemplateBuilder MobileYouTubePlugin::GetObjectTemplateBuilder( + v8::Isolate* isolate) { + return PluginPlaceholder::GetObjectTemplateBuilder(isolate) + .SetMethod("openYoutubeURL", &MobileYouTubePlugin::OpenYoutubeUrlCallback); } } // namespace plugins diff --git a/components/plugins/renderer/mobile_youtube_plugin.h b/components/plugins/renderer/mobile_youtube_plugin.h index 2fad63a..a7654da 100644 --- a/components/plugins/renderer/mobile_youtube_plugin.h +++ b/components/plugins/renderer/mobile_youtube_plugin.h @@ -26,13 +26,18 @@ class MobileYouTubePlugin : public PluginPlaceholder { static bool IsYouTubeURL(const GURL& url, const std::string& mime_type); private: + virtual ~MobileYouTubePlugin(); + // Opens a youtube app in the current tab. - void OpenYoutubeUrlCallback(const webkit_glue::CppArgumentList& args, - webkit_glue::CppVariant* result); + void OpenYoutubeUrlCallback(); // WebViewPlugin::Delegate (via PluginPlaceholder) method virtual void BindWebFrame(blink::WebFrame* frame) OVERRIDE; + // gin::Wrappable (via PluginPlaceholder) method + virtual gin::ObjectTemplateBuilder GetObjectTemplateBuilder( + v8::Isolate* isolate) OVERRIDE; + DISALLOW_COPY_AND_ASSIGN(MobileYouTubePlugin); }; diff --git a/components/plugins/renderer/plugin_placeholder.cc b/components/plugins/renderer/plugin_placeholder.cc index 405ac86..343c7ad 100644 --- a/components/plugins/renderer/plugin_placeholder.cc +++ b/components/plugins/renderer/plugin_placeholder.cc @@ -15,6 +15,7 @@ #include "content/public/common/context_menu_params.h" #include "content/public/renderer/render_frame.h" #include "content/public/renderer/render_thread.h" +#include "gin/object_template_builder.h" #include "third_party/WebKit/public/web/WebDocument.h" #include "third_party/WebKit/public/web/WebElement.h" #include "third_party/WebKit/public/web/WebFrame.h" @@ -35,11 +36,11 @@ using blink::WebPluginContainer; using blink::WebPluginParams; using blink::WebScriptSource; using blink::WebURLRequest; -using webkit_glue::CppArgumentList; -using webkit_glue::CppVariant; namespace plugins { +gin::WrapperInfo PluginPlaceholder::kWrapperInfo = {gin::kEmbedderNativeGin}; + PluginPlaceholder::PluginPlaceholder(content::RenderFrame* render_frame, WebFrame* frame, const WebPluginParams& params, @@ -59,17 +60,13 @@ PluginPlaceholder::PluginPlaceholder(content::RenderFrame* render_frame, PluginPlaceholder::~PluginPlaceholder() {} -void PluginPlaceholder::BindWebFrame(WebFrame* frame) { - BindToJavascript(frame, "plugin"); - BindCallback( - "load", - base::Bind(&PluginPlaceholder::LoadCallback, base::Unretained(this))); - BindCallback( - "hide", - base::Bind(&PluginPlaceholder::HideCallback, base::Unretained(this))); - BindCallback("didFinishLoading", - base::Bind(&PluginPlaceholder::DidFinishLoadingCallback, - base::Unretained(this))); +gin::ObjectTemplateBuilder PluginPlaceholder::GetObjectTemplateBuilder( + v8::Isolate* isolate) { + return gin::Wrappable<PluginPlaceholder>::GetObjectTemplateBuilder(isolate) + .SetMethod("load", &PluginPlaceholder::LoadCallback) + .SetMethod("hide", &PluginPlaceholder::HideCallback) + .SetMethod("didFinishLoading", + &PluginPlaceholder::DidFinishLoadingCallback); } void PluginPlaceholder::ReplacePlugin(WebPlugin* new_plugin) { @@ -87,10 +84,11 @@ void PluginPlaceholder::ReplacePlugin(WebPlugin* new_plugin) { return; } - // The plug-in has been removed from the page. Destroy the old plug-in - // (which will destroy us). + // The plug-in has been removed from the page. Destroy the old plug-in. We + // will be destroyed as soon as V8 garbage collects us. if (!element.pluginContainer()) { plugin_->destroy(); + plugin_ = NULL; return; } @@ -104,6 +102,7 @@ void PluginPlaceholder::ReplacePlugin(WebPlugin* new_plugin) { container->reportGeometry(); plugin_->ReplayReceivedData(new_plugin); plugin_->destroy(); + plugin_ = NULL; } void PluginPlaceholder::HidePlugin() { @@ -152,8 +151,6 @@ void PluginPlaceholder::HidePlugin() { } } -void PluginPlaceholder::WillDestroyPlugin() { delete this; } - void PluginPlaceholder::SetMessage(const base::string16& message) { message_ = message; if (finished_loading_) @@ -173,6 +170,10 @@ void PluginPlaceholder::ShowContextMenu(const WebMouseEvent& event) { return; } +void PluginPlaceholder::OnDestruct() { + frame_ = NULL; +} + void PluginPlaceholder::OnLoadBlockedPlugins(const std::string& identifier) { if (!identifier.empty() && identifier != identifier_) return; @@ -207,20 +208,17 @@ void PluginPlaceholder::LoadPlugin() { ReplacePlugin(plugin); } -void PluginPlaceholder::LoadCallback(const CppArgumentList& args, - CppVariant* result) { +void PluginPlaceholder::LoadCallback() { RenderThread::Get()->RecordAction(UserMetricsAction("Plugin_Load_Click")); LoadPlugin(); } -void PluginPlaceholder::HideCallback(const CppArgumentList& args, - CppVariant* result) { +void PluginPlaceholder::HideCallback() { RenderThread::Get()->RecordAction(UserMetricsAction("Plugin_Hide_Click")); HidePlugin(); } -void PluginPlaceholder::DidFinishLoadingCallback(const CppArgumentList& args, - CppVariant* result) { +void PluginPlaceholder::DidFinishLoadingCallback() { finished_loading_ = true; if (message_.length() > 0) UpdateMessage(); diff --git a/components/plugins/renderer/plugin_placeholder.h b/components/plugins/renderer/plugin_placeholder.h index d8b7d1a..c1cbbce 100644 --- a/components/plugins/renderer/plugin_placeholder.h +++ b/components/plugins/renderer/plugin_placeholder.h @@ -10,8 +10,8 @@ #include "content/public/renderer/context_menu_client.h" #include "content/public/renderer/render_frame_observer.h" #include "content/public/renderer/render_process_observer.h" +#include "gin/wrappable.h" #include "third_party/WebKit/public/web/WebPluginParams.h" -#include "webkit/renderer/cpp_bound_class.h" namespace content { struct WebPluginInfo; @@ -21,9 +21,10 @@ namespace plugins { // Placeholders can be used if a plug-in is missing or not available // (blocked or disabled). class PluginPlaceholder : public content::RenderFrameObserver, - public webkit_glue::CppBoundClass, - public WebViewPlugin::Delegate { + public WebViewPlugin::Delegate, + public gin::Wrappable<PluginPlaceholder> { public: + static gin::WrapperInfo kWrapperInfo; WebViewPlugin* plugin() { return plugin_; } @@ -65,28 +66,26 @@ class PluginPlaceholder : public content::RenderFrameObserver, // Load the blocked plugin. void LoadPlugin(); - // WebViewPlugin::Delegate method: - virtual void BindWebFrame(blink::WebFrame* frame) OVERRIDE; + // gin::Wrappable method: + virtual gin::ObjectTemplateBuilder GetObjectTemplateBuilder( + v8::Isolate* isolate) OVERRIDE; private: // WebViewPlugin::Delegate methods: - virtual void WillDestroyPlugin() OVERRIDE; virtual void ShowContextMenu(const blink::WebMouseEvent&) OVERRIDE; + // RenderFrameObserver methods: + virtual void OnDestruct() OVERRIDE; + // Javascript callbacks: - // All ignore arguments (which are, however, required by caller) and return - // nothing. // Load the blocked plugin by calling LoadPlugin(). - void LoadCallback(const webkit_glue::CppArgumentList& args, - webkit_glue::CppVariant* result); + void LoadCallback(); // Hide the blocked plugin by calling HidePlugin(). - void HideCallback(const webkit_glue::CppArgumentList& args, - webkit_glue::CppVariant* result); + void HideCallback(); - void DidFinishLoadingCallback(const webkit_glue::CppArgumentList& args, - webkit_glue::CppVariant* result); + void DidFinishLoadingCallback(); void UpdateMessage(); diff --git a/components/plugins/renderer/webview_plugin.cc b/components/plugins/renderer/webview_plugin.cc index ccacc06..22c7ed2 100644 --- a/components/plugins/renderer/webview_plugin.cc +++ b/components/plugins/renderer/webview_plugin.cc @@ -107,10 +107,8 @@ bool WebViewPlugin::initialize(WebPluginContainer* container) { } void WebViewPlugin::destroy() { - if (delegate_) { - delegate_->WillDestroyPlugin(); + if (delegate_) delegate_ = NULL; - } container_ = NULL; base::MessageLoop::current()->DeleteSoon(FROM_HERE, this); } diff --git a/components/plugins/renderer/webview_plugin.h b/components/plugins/renderer/webview_plugin.h index 8ec76c4..4f463a7 100644 --- a/components/plugins/renderer/webview_plugin.h +++ b/components/plugins/renderer/webview_plugin.h @@ -40,10 +40,6 @@ class WebViewPlugin : public blink::WebPlugin, // This method is called from WebFrameClient::didClearWindowObject. virtual void BindWebFrame(blink::WebFrame* frame) = 0; - // Called before the WebViewPlugin is destroyed. The delegate should delete - // itself here. - virtual void WillDestroyPlugin() = 0; - // Called upon a context menu event. virtual void ShowContextMenu(const blink::WebMouseEvent&) = 0; }; @@ -136,13 +132,17 @@ class WebViewPlugin : public blink::WebPlugin, friend class base::DeleteHelper<WebViewPlugin>; virtual ~WebViewPlugin(); + // Manages its own lifetime. Delegate* delegate_; - // Destroys itself. + blink::WebCursorInfo current_cursor_; + // Owns us. blink::WebPluginContainer* container_; + // Owned by us, deleted via |close()|. blink::WebView* web_view_; + // Owned by us, deleted via |close()|. blink::WebFrame* web_frame_; gfx::Rect rect_; |