| 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 "webkit/plugins/ppapi/ppapi_webplugin_impl.h" | 5 #include "webkit/plugins/ppapi/ppapi_webplugin_impl.h" |
| 6 | 6 |
| 7 #include <cmath> | 7 #include <cmath> |
| 8 | 8 |
| 9 #include "base/debug/crash_logging.h" | 9 #include "base/debug/crash_logging.h" |
| 10 #include "base/message_loop.h" | 10 #include "base/message_loop.h" |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 86 // The plugin delegate may have gone away. | 86 // The plugin delegate may have gone away. |
| 87 if (!init_data_->delegate) | 87 if (!init_data_->delegate) |
| 88 return false; | 88 return false; |
| 89 | 89 |
| 90 instance_ = init_data_->module->CreateInstance(init_data_->delegate, | 90 instance_ = init_data_->module->CreateInstance(init_data_->delegate, |
| 91 container, | 91 container, |
| 92 init_data_->url); | 92 init_data_->url); |
| 93 if (!instance_) | 93 if (!instance_) |
| 94 return false; | 94 return false; |
| 95 | 95 |
| 96 // Enable script objects for this plugin. |
| 97 container->allowScriptObjects(); |
| 98 |
| 96 bool success = instance_->Initialize(init_data_->arg_names, | 99 bool success = instance_->Initialize(init_data_->arg_names, |
| 97 init_data_->arg_values, | 100 init_data_->arg_values, |
| 98 full_frame_); | 101 full_frame_); |
| 99 if (!success) { | 102 if (!success) { |
| 100 instance_->Delete(); | 103 instance_->Delete(); |
| 101 instance_ = NULL; | 104 instance_ = NULL; |
| 102 | 105 |
| 103 WebKit::WebPlugin* replacement_plugin = | 106 WebKit::WebPlugin* replacement_plugin = |
| 104 init_data_->delegate->CreatePluginReplacement( | 107 init_data_->delegate->CreatePluginReplacement( |
| 105 init_data_->module->path()); | 108 init_data_->module->path()); |
| 106 if (!replacement_plugin || !replacement_plugin->initialize(container)) | 109 if (!replacement_plugin || !replacement_plugin->initialize(container)) |
| 107 return false; | 110 return false; |
| 108 | 111 |
| 109 container->setPlugin(replacement_plugin); | 112 container->setPlugin(replacement_plugin); |
| 110 return true; | 113 return true; |
| 111 } | 114 } |
| 112 | 115 |
| 113 init_data_.reset(); | 116 init_data_.reset(); |
| 114 container_ = container; | 117 container_ = container; |
| 115 return true; | 118 return true; |
| 116 } | 119 } |
| 117 | 120 |
| 118 void WebPluginImpl::destroy() { | 121 void WebPluginImpl::destroy() { |
| 122 // Tell |container_| to clear references to this plugin's script objects. |
| 123 container_->clearScriptObjects(); |
| 124 |
| 119 if (instance_) { | 125 if (instance_) { |
| 120 ::ppapi::PpapiGlobals::Get()->GetVarTracker()->ReleaseVar(instance_object_); | 126 ::ppapi::PpapiGlobals::Get()->GetVarTracker()->ReleaseVar(instance_object_); |
| 121 instance_object_ = PP_MakeUndefined(); | 127 instance_object_ = PP_MakeUndefined(); |
| 122 instance_->Delete(); | 128 instance_->Delete(); |
| 123 instance_ = NULL; | 129 instance_ = NULL; |
| 124 } | 130 } |
| 125 | 131 |
| 126 base::MessageLoop::current()->DeleteSoon(FROM_HERE, this); | 132 base::MessageLoop::current()->DeleteSoon(FROM_HERE, this); |
| 127 } | 133 } |
| 128 | 134 |
| (...skipping 12 matching lines...) Expand all Loading... |
| 141 // any non-postMessage calls to it. | 147 // any non-postMessage calls to it. |
| 142 if (object) { | 148 if (object) { |
| 143 instance_->message_channel().SetPassthroughObject(object->np_object()); | 149 instance_->message_channel().SetPassthroughObject(object->np_object()); |
| 144 } | 150 } |
| 145 NPObject* message_channel_np_object(instance_->message_channel().np_object()); | 151 NPObject* message_channel_np_object(instance_->message_channel().np_object()); |
| 146 // The object is expected to be retained before it is returned. | 152 // The object is expected to be retained before it is returned. |
| 147 WebKit::WebBindings::retainObject(message_channel_np_object); | 153 WebKit::WebBindings::retainObject(message_channel_np_object); |
| 148 return message_channel_np_object; | 154 return message_channel_np_object; |
| 149 } | 155 } |
| 150 | 156 |
| 157 NPP WebPluginImpl::pluginNPP() { |
| 158 return instance_->instanceNPP(); |
| 159 } |
| 160 |
| 151 bool WebPluginImpl::getFormValue(WebString& value) { | 161 bool WebPluginImpl::getFormValue(WebString& value) { |
| 152 return false; | 162 return false; |
| 153 } | 163 } |
| 154 | 164 |
| 155 void WebPluginImpl::paint(WebCanvas* canvas, const WebRect& rect) { | 165 void WebPluginImpl::paint(WebCanvas* canvas, const WebRect& rect) { |
| 156 if (!instance_->FlashIsFullscreenOrPending()) | 166 if (!instance_->FlashIsFullscreenOrPending()) |
| 157 instance_->Paint(canvas, plugin_rect_, rect); | 167 instance_->Paint(canvas, plugin_rect_, rect); |
| 158 } | 168 } |
| 159 | 169 |
| 160 void WebPluginImpl::updateGeometry( | 170 void WebPluginImpl::updateGeometry( |
| (...skipping 124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 285 void WebPluginImpl::rotateView(RotationType type) { | 295 void WebPluginImpl::rotateView(RotationType type) { |
| 286 instance_->RotateView(type); | 296 instance_->RotateView(type); |
| 287 } | 297 } |
| 288 | 298 |
| 289 bool WebPluginImpl::isPlaceholder() { | 299 bool WebPluginImpl::isPlaceholder() { |
| 290 return false; | 300 return false; |
| 291 } | 301 } |
| 292 | 302 |
| 293 } // namespace ppapi | 303 } // namespace ppapi |
| 294 } // namespace webkit | 304 } // namespace webkit |
| OLD | NEW |