Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(288)

Side by Side Diff: content/renderer/pepper/pepper_plugin_instance_impl.cc

Issue 459553003: Replace NPObject usage in ppapi with gin (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/pepper/pepper_plugin_instance_impl.h" 5 #include "content/renderer/pepper/pepper_plugin_instance_impl.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/callback_helpers.h" 8 #include "base/callback_helpers.h"
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "base/debug/trace_event.h" 10 #include "base/debug/trace_event.h"
(...skipping 15 matching lines...) Expand all
26 #include "content/public/renderer/content_renderer_client.h" 26 #include "content/public/renderer/content_renderer_client.h"
27 #include "content/renderer/compositor_bindings/web_layer_impl.h" 27 #include "content/renderer/compositor_bindings/web_layer_impl.h"
28 #include "content/renderer/gpu/render_widget_compositor.h" 28 #include "content/renderer/gpu/render_widget_compositor.h"
29 #include "content/renderer/pepper/content_decryptor_delegate.h" 29 #include "content/renderer/pepper/content_decryptor_delegate.h"
30 #include "content/renderer/pepper/event_conversion.h" 30 #include "content/renderer/pepper/event_conversion.h"
31 #include "content/renderer/pepper/fullscreen_container.h" 31 #include "content/renderer/pepper/fullscreen_container.h"
32 #include "content/renderer/pepper/gfx_conversion.h" 32 #include "content/renderer/pepper/gfx_conversion.h"
33 #include "content/renderer/pepper/host_dispatcher_wrapper.h" 33 #include "content/renderer/pepper/host_dispatcher_wrapper.h"
34 #include "content/renderer/pepper/host_globals.h" 34 #include "content/renderer/pepper/host_globals.h"
35 #include "content/renderer/pepper/message_channel.h" 35 #include "content/renderer/pepper/message_channel.h"
36 #include "content/renderer/pepper/npapi_glue.h"
37 #include "content/renderer/pepper/pepper_browser_connection.h" 36 #include "content/renderer/pepper/pepper_browser_connection.h"
38 #include "content/renderer/pepper/pepper_compositor_host.h" 37 #include "content/renderer/pepper/pepper_compositor_host.h"
39 #include "content/renderer/pepper/pepper_file_ref_renderer_host.h" 38 #include "content/renderer/pepper/pepper_file_ref_renderer_host.h"
40 #include "content/renderer/pepper/pepper_graphics_2d_host.h" 39 #include "content/renderer/pepper/pepper_graphics_2d_host.h"
41 #include "content/renderer/pepper/pepper_in_process_router.h" 40 #include "content/renderer/pepper/pepper_in_process_router.h"
41 #include "content/renderer/pepper/pepper_try_catch.h"
42 #include "content/renderer/pepper/pepper_url_loader_host.h" 42 #include "content/renderer/pepper/pepper_url_loader_host.h"
43 #include "content/renderer/pepper/plugin_module.h" 43 #include "content/renderer/pepper/plugin_module.h"
44 #include "content/renderer/pepper/plugin_object.h" 44 #include "content/renderer/pepper/plugin_object.h"
45 #include "content/renderer/pepper/ppapi_preferences_builder.h" 45 #include "content/renderer/pepper/ppapi_preferences_builder.h"
46 #include "content/renderer/pepper/ppb_buffer_impl.h" 46 #include "content/renderer/pepper/ppb_buffer_impl.h"
47 #include "content/renderer/pepper/ppb_graphics_3d_impl.h" 47 #include "content/renderer/pepper/ppb_graphics_3d_impl.h"
48 #include "content/renderer/pepper/ppb_image_data_impl.h" 48 #include "content/renderer/pepper/ppb_image_data_impl.h"
49 #include "content/renderer/pepper/renderer_ppapi_host_impl.h" 49 #include "content/renderer/pepper/renderer_ppapi_host_impl.h"
50 #include "content/renderer/pepper/url_request_info_util.h" 50 #include "content/renderer/pepper/url_request_info_util.h"
51 #include "content/renderer/pepper/url_response_info_util.h" 51 #include "content/renderer/pepper/url_response_info_util.h"
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
108 #include "third_party/WebKit/public/web/WebCompositionUnderline.h" 108 #include "third_party/WebKit/public/web/WebCompositionUnderline.h"
109 #include "third_party/WebKit/public/web/WebDataSource.h" 109 #include "third_party/WebKit/public/web/WebDataSource.h"
110 #include "third_party/WebKit/public/web/WebDocument.h" 110 #include "third_party/WebKit/public/web/WebDocument.h"
111 #include "third_party/WebKit/public/web/WebElement.h" 111 #include "third_party/WebKit/public/web/WebElement.h"
112 #include "third_party/WebKit/public/web/WebInputEvent.h" 112 #include "third_party/WebKit/public/web/WebInputEvent.h"
113 #include "third_party/WebKit/public/web/WebLocalFrame.h" 113 #include "third_party/WebKit/public/web/WebLocalFrame.h"
114 #include "third_party/WebKit/public/web/WebPluginContainer.h" 114 #include "third_party/WebKit/public/web/WebPluginContainer.h"
115 #include "third_party/WebKit/public/web/WebPrintParams.h" 115 #include "third_party/WebKit/public/web/WebPrintParams.h"
116 #include "third_party/WebKit/public/web/WebPrintScalingOption.h" 116 #include "third_party/WebKit/public/web/WebPrintScalingOption.h"
117 #include "third_party/WebKit/public/web/WebScopedUserGesture.h" 117 #include "third_party/WebKit/public/web/WebScopedUserGesture.h"
118 #include "third_party/WebKit/public/web/WebScriptSource.h"
118 #include "third_party/WebKit/public/web/WebSecurityOrigin.h" 119 #include "third_party/WebKit/public/web/WebSecurityOrigin.h"
119 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h" 120 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h"
120 #include "third_party/WebKit/public/web/WebView.h" 121 #include "third_party/WebKit/public/web/WebView.h"
121 #include "third_party/khronos/GLES2/gl2.h" 122 #include "third_party/khronos/GLES2/gl2.h"
122 #include "third_party/skia/include/core/SkCanvas.h" 123 #include "third_party/skia/include/core/SkCanvas.h"
123 #include "third_party/skia/include/core/SkRect.h" 124 #include "third_party/skia/include/core/SkRect.h"
124 #include "ui/gfx/image/image_skia.h" 125 #include "ui/gfx/image/image_skia.h"
125 #include "ui/gfx/image/image_skia_rep.h" 126 #include "ui/gfx/image/image_skia_rep.h"
126 #include "ui/gfx/range/range.h" 127 #include "ui/gfx/range/range.h"
127 #include "ui/gfx/rect_conversions.h" 128 #include "ui/gfx/rect_conversions.h"
(...skipping 424 matching lines...) Expand 10 before | Expand all | Expand 10 after
552 filtered_input_event_mask_(0), 553 filtered_input_event_mask_(0),
553 text_input_type_(kPluginDefaultTextInputType), 554 text_input_type_(kPluginDefaultTextInputType),
554 text_input_caret_(0, 0, 0, 0), 555 text_input_caret_(0, 0, 0, 0),
555 text_input_caret_bounds_(0, 0, 0, 0), 556 text_input_caret_bounds_(0, 0, 0, 0),
556 text_input_caret_set_(false), 557 text_input_caret_set_(false),
557 selection_caret_(0), 558 selection_caret_(0),
558 selection_anchor_(0), 559 selection_anchor_(0),
559 pending_user_gesture_(0.0), 560 pending_user_gesture_(0.0),
560 document_loader_(NULL), 561 document_loader_(NULL),
561 external_document_load_(false), 562 external_document_load_(false),
562 npp_(new NPP_t),
563 isolate_(v8::Isolate::GetCurrent()), 563 isolate_(v8::Isolate::GetCurrent()),
564 is_deleted_(false), 564 is_deleted_(false),
565 last_input_number_(0), 565 last_input_number_(0),
566 is_tracking_latency_(false), 566 is_tracking_latency_(false),
567 view_change_weak_ptr_factory_(this), 567 view_change_weak_ptr_factory_(this),
568 weak_factory_(this) { 568 weak_factory_(this) {
569 pp_instance_ = HostGlobals::Get()->AddInstance(this); 569 pp_instance_ = HostGlobals::Get()->AddInstance(this);
570 570
571 memset(&current_print_settings_, 0, sizeof(current_print_settings_)); 571 memset(&current_print_settings_, 0, sizeof(current_print_settings_));
572 module_->InstanceCreated(this); 572 module_->InstanceCreated(this);
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
613 resource_creation_ = host_impl->CreateInProcessResourceCreationAPI(this); 613 resource_creation_ = host_impl->CreateInProcessResourceCreationAPI(this);
614 614
615 if (GetContentClient()->renderer() && // NULL in unit tests. 615 if (GetContentClient()->renderer() && // NULL in unit tests.
616 GetContentClient()->renderer()->IsExternalPepperPlugin(module->name())) 616 GetContentClient()->renderer()->IsExternalPepperPlugin(module->name()))
617 external_document_load_ = true; 617 external_document_load_ = true;
618 } 618 }
619 619
620 PepperPluginInstanceImpl::~PepperPluginInstanceImpl() { 620 PepperPluginInstanceImpl::~PepperPluginInstanceImpl() {
621 DCHECK(!fullscreen_container_); 621 DCHECK(!fullscreen_container_);
622 622
623 // Free all the plugin objects. This will automatically clear the back- 623 // Notify all the plugin objects of deletion. This will prevent WebKit from
624 // pointer from the NPObject so WebKit can't call into the plugin any more. 624 // calling into the plugin any more.
625 //
626 // Swap out the set so we can delete from it (the objects will try to
627 // unregister themselves inside the delete call).
628 PluginObjectSet plugin_object_copy; 625 PluginObjectSet plugin_object_copy;
629 live_plugin_objects_.swap(plugin_object_copy); 626 live_plugin_objects_.swap(plugin_object_copy);
630 for (PluginObjectSet::iterator i = plugin_object_copy.begin(); 627 for (PluginObjectSet::iterator i = plugin_object_copy.begin();
631 i != plugin_object_copy.end(); 628 i != plugin_object_copy.end();
632 ++i) 629 ++i) {
633 delete *i; 630 (*i)->InstanceDeleted();
631 }
634 632
635 if (TrackedCallback::IsPending(lock_mouse_callback_)) 633 if (TrackedCallback::IsPending(lock_mouse_callback_))
636 lock_mouse_callback_->Abort(); 634 lock_mouse_callback_->Abort();
637 635
638 if (!instance_deleted_callback_.is_null()) 636 if (!instance_deleted_callback_.is_null())
639 instance_deleted_callback_.Run(); 637 instance_deleted_callback_.Run();
640 638
641 if (!module_->IsProxied() && render_frame_) { 639 if (!module_->IsProxied() && render_frame_) {
642 PepperBrowserConnection* browser_connection = 640 PepperBrowserConnection* browser_connection =
643 PepperBrowserConnection::Get(render_frame_); 641 PepperBrowserConnection::Get(render_frame_);
(...skipping 10 matching lines...) Expand all
654 // want to look up in the global map to get info off of our object. 652 // want to look up in the global map to get info off of our object.
655 HostGlobals::Get()->InstanceDeleted(pp_instance_); 653 HostGlobals::Get()->InstanceDeleted(pp_instance_);
656 } 654 }
657 655
658 // NOTE: Any of these methods that calls into the plugin needs to take into 656 // NOTE: Any of these methods that calls into the plugin needs to take into
659 // account that the plugin may use Var to remove the <embed> from the DOM, which 657 // account that the plugin may use Var to remove the <embed> from the DOM, which
660 // will make the PepperWebPluginImpl drop its reference, usually the last one. 658 // will make the PepperWebPluginImpl drop its reference, usually the last one.
661 // If a method needs to access a member of the instance after the call has 659 // If a method needs to access a member of the instance after the call has
662 // returned, then it needs to keep its own reference on the stack. 660 // returned, then it needs to keep its own reference on the stack.
663 661
662 v8::Local<v8::Object> PepperPluginInstanceImpl::GetMessageChannelObject() {
663 return v8::Local<v8::Object>::New(isolate_, message_channel_);
664 }
665
666 MessageChannel* PepperPluginInstanceImpl::GetMessageChannel() {
667 MessageChannel* message_channel;
jochen (gone - plz use gerrit) 2014/08/13 14:17:07 NULL initialize?
raymes 2014/08/14 00:47:57 Done.
668 v8::HandleScope scope(isolate_);
669 v8::Context::Scope context_scope(GetContext());
670 if (gin::ConvertFromV8(isolate_, GetMessageChannelObject(), &message_channel))
671 return message_channel;
672 return NULL;
673 }
674
664 v8::Local<v8::Context> PepperPluginInstanceImpl::GetContext() { 675 v8::Local<v8::Context> PepperPluginInstanceImpl::GetContext() {
665 if (!container_) 676 if (!container_)
666 return v8::Handle<v8::Context>(); 677 return v8::Handle<v8::Context>();
667 WebLocalFrame* frame = container_->element().document().frame(); 678 WebLocalFrame* frame = container_->element().document().frame();
668 if (!frame) 679 if (!frame)
669 return v8::Handle<v8::Context>(); 680 return v8::Handle<v8::Context>();
670 681
671 v8::Local<v8::Context> context = frame->mainWorldScriptContext(); 682 v8::Local<v8::Context> context = frame->mainWorldScriptContext();
672 DCHECK(context->GetIsolate() == isolate_); 683 DCHECK(context->GetIsolate() == isolate_);
673 return context; 684 return context;
674 } 685 }
675 686
676 void PepperPluginInstanceImpl::Delete() { 687 void PepperPluginInstanceImpl::Delete() {
677 is_deleted_ = true; 688 is_deleted_ = true;
678 689
679 if (render_frame_ && 690 if (render_frame_ &&
680 render_frame_->render_view()->plugin_find_handler() == this) { 691 render_frame_->render_view()->plugin_find_handler() == this) {
681 render_frame_->render_view()->set_plugin_find_handler(NULL); 692 render_frame_->render_view()->set_plugin_find_handler(NULL);
682 } 693 }
683 694
684 // Keep a reference on the stack. See NOTE above. 695 // Keep a reference on the stack. See NOTE above.
685 scoped_refptr<PepperPluginInstanceImpl> ref(this); 696 scoped_refptr<PepperPluginInstanceImpl> ref(this);
686 // Force the MessageChannel to release its "passthrough object" which should 697 // Force the MessageChannel to release its "passthrough object" which should
687 // release our last reference to the "InstanceObject" and will probably 698 // release our last reference to the "InstanceObject" and will probably
688 // destroy it. We want to do this prior to calling DidDestroy in case the 699 // destroy it. We want to do this prior to calling DidDestroy in case the
689 // destructor of the instance object tries to use the instance. 700 // destructor of the instance object tries to use the instance.
690 message_channel_->SetPassthroughObject(NULL); 701 GetMessageChannel()->SetPassthroughObject(v8::Handle<v8::Object>());
691 // If this is a NaCl plugin instance, shut down the NaCl plugin by calling 702 // If this is a NaCl plugin instance, shut down the NaCl plugin by calling
692 // its DidDestroy. Don't call DidDestroy on the untrusted plugin instance, 703 // its DidDestroy. Don't call DidDestroy on the untrusted plugin instance,
693 // since there is little that it can do at this point. 704 // since there is little that it can do at this point.
694 if (original_instance_interface_) 705 if (original_instance_interface_)
695 original_instance_interface_->DidDestroy(pp_instance()); 706 original_instance_interface_->DidDestroy(pp_instance());
696 else 707 else
697 instance_interface_->DidDestroy(pp_instance()); 708 instance_interface_->DidDestroy(pp_instance());
698 // Ensure we don't attempt to call functions on the destroyed instance. 709 // Ensure we don't attempt to call functions on the destroyed instance.
699 original_instance_interface_.reset(); 710 original_instance_interface_.reset();
700 instance_interface_.reset(); 711 instance_interface_.reset();
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after
842 "Flash.UsesGPU", is_xp * 4 + needs_gpu * 2 + prefs.is_webgl_supported, 8); 853 "Flash.UsesGPU", is_xp * 4 + needs_gpu * 2 + prefs.is_webgl_supported, 8);
843 #endif 854 #endif
844 } 855 }
845 856
846 bool PepperPluginInstanceImpl::Initialize( 857 bool PepperPluginInstanceImpl::Initialize(
847 const std::vector<std::string>& arg_names, 858 const std::vector<std::string>& arg_names,
848 const std::vector<std::string>& arg_values, 859 const std::vector<std::string>& arg_values,
849 bool full_frame) { 860 bool full_frame) {
850 if (!render_frame_) 861 if (!render_frame_)
851 return false; 862 return false;
852 message_channel_.reset(new MessageChannel(this)); 863 MessageChannel::Create(this, &message_channel_);
853 864
854 full_frame_ = full_frame; 865 full_frame_ = full_frame;
855 866
856 UpdateTouchEventRequest(); 867 UpdateTouchEventRequest();
857 container_->setWantsWheelEvents(IsAcceptingWheelEvents()); 868 container_->setWantsWheelEvents(IsAcceptingWheelEvents());
858 869
859 SetGPUHistogram(ppapi::Preferences(PpapiPreferencesBuilder::Build( 870 SetGPUHistogram(ppapi::Preferences(PpapiPreferencesBuilder::Build(
860 render_frame_->render_view()->webkit_preferences())), 871 render_frame_->render_view()->webkit_preferences())),
861 arg_names, 872 arg_names,
862 arg_values); 873 arg_values);
863 874
864 argn_ = arg_names; 875 argn_ = arg_names;
865 argv_ = arg_values; 876 argv_ = arg_values;
866 scoped_ptr<const char * []> argn_array(StringVectorToArgArray(argn_)); 877 scoped_ptr<const char * []> argn_array(StringVectorToArgArray(argn_));
867 scoped_ptr<const char * []> argv_array(StringVectorToArgArray(argv_)); 878 scoped_ptr<const char * []> argv_array(StringVectorToArgArray(argv_));
868 bool success = PP_ToBool(instance_interface_->DidCreate( 879 bool success = PP_ToBool(instance_interface_->DidCreate(
869 pp_instance(), argn_.size(), argn_array.get(), argv_array.get())); 880 pp_instance(), argn_.size(), argn_array.get(), argv_array.get()));
870 // If this is a plugin that hosts external plugins, we should delay messages 881 // If this is a plugin that hosts external plugins, we should delay messages
871 // so that the child plugin that's created later will receive all the 882 // so that the child plugin that's created later will receive all the
872 // messages. (E.g., NaCl trusted plugin starting a child NaCl app.) 883 // messages. (E.g., NaCl trusted plugin starting a child NaCl app.)
873 // 884 //
874 // A host for external plugins will call ResetAsProxied later, at which point 885 // A host for external plugins will call ResetAsProxied later, at which point
875 // we can Start() the message_channel_. 886 // we can Start() the message_channel_.
876 if (success && (!module_->renderer_ppapi_host()->IsExternalPluginHost())) 887 if (success && (!module_->renderer_ppapi_host()->IsExternalPluginHost()))
877 message_channel_->Start(); 888 GetMessageChannel()->Start();
878 return success; 889 return success;
879 } 890 }
880 891
881 bool PepperPluginInstanceImpl::HandleDocumentLoad( 892 bool PepperPluginInstanceImpl::HandleDocumentLoad(
882 const blink::WebURLResponse& response) { 893 const blink::WebURLResponse& response) {
883 DCHECK(!document_loader_); 894 DCHECK(!document_loader_);
884 if (external_document_load_) { 895 if (external_document_load_) {
885 // The external proxy isn't available, so save the response and record 896 // The external proxy isn't available, so save the response and record
886 // document load notifications for later replay. 897 // document load notifications for later replay.
887 external_document_response_ = response; 898 external_document_response_ = response;
(...skipping 323 matching lines...) Expand 10 before | Expand all | Expand 10 after
1211 ppapi::proxy::SerializedVarSendInputShmem(dispatcher, message.get(), 1222 ppapi::proxy::SerializedVarSendInputShmem(dispatcher, message.get(),
1212 pp_instance()), 1223 pp_instance()),
1213 &msg_reply, 1224 &msg_reply,
1214 &was_handled)); 1225 &was_handled));
1215 *result = ScopedPPVar(ScopedPPVar::PassRef(), msg_reply.Return(dispatcher)); 1226 *result = ScopedPPVar(ScopedPPVar::PassRef(), msg_reply.Return(dispatcher));
1216 TRACE_EVENT0("ppapi", 1227 TRACE_EVENT0("ppapi",
1217 "PepperPluginInstanceImpl::HandleBlockingMessage return."); 1228 "PepperPluginInstanceImpl::HandleBlockingMessage return.");
1218 return was_handled; 1229 return was_handled;
1219 } 1230 }
1220 1231
1221 PP_Var PepperPluginInstanceImpl::GetInstanceObject() { 1232 PP_Var PepperPluginInstanceImpl::GetInstanceObject(v8::Isolate* isolate) {
1222 // Keep a reference on the stack. See NOTE above. 1233 // Keep a reference on the stack. See NOTE above.
1223 scoped_refptr<PepperPluginInstanceImpl> ref(this); 1234 scoped_refptr<PepperPluginInstanceImpl> ref(this);
1224 1235
1236 DCHECK(isolate == isolate_);
jochen (gone - plz use gerrit) 2014/08/13 14:17:07 DCHECK_EQ
raymes 2014/08/14 00:47:57 Done.
1237
1225 // If the plugin supports the private instance interface, try to retrieve its 1238 // If the plugin supports the private instance interface, try to retrieve its
1226 // instance object. 1239 // instance object.
1227 if (LoadPrivateInterface()) 1240 if (LoadPrivateInterface())
1228 return plugin_private_interface_->GetInstanceObject(pp_instance()); 1241 return plugin_private_interface_->GetInstanceObject(pp_instance());
1229 return PP_MakeUndefined(); 1242 return PP_MakeUndefined();
1230 } 1243 }
1231 1244
1232 void PepperPluginInstanceImpl::ViewChanged( 1245 void PepperPluginInstanceImpl::ViewChanged(
1233 const gfx::Rect& position, 1246 const gfx::Rect& position,
1234 const gfx::Rect& clip, 1247 const gfx::Rect& clip,
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after
1350 void PepperPluginInstanceImpl::SetLinkUnderCursor(const std::string& url) { 1363 void PepperPluginInstanceImpl::SetLinkUnderCursor(const std::string& url) {
1351 link_under_cursor_ = base::UTF8ToUTF16(url); 1364 link_under_cursor_ = base::UTF8ToUTF16(url);
1352 } 1365 }
1353 1366
1354 void PepperPluginInstanceImpl::SetTextInputType(ui::TextInputType type) { 1367 void PepperPluginInstanceImpl::SetTextInputType(ui::TextInputType type) {
1355 text_input_type_ = type; 1368 text_input_type_ = type;
1356 render_frame_->PepperTextInputTypeChanged(this); 1369 render_frame_->PepperTextInputTypeChanged(this);
1357 } 1370 }
1358 1371
1359 void PepperPluginInstanceImpl::PostMessageToJavaScript(PP_Var message) { 1372 void PepperPluginInstanceImpl::PostMessageToJavaScript(PP_Var message) {
1360 message_channel_->PostMessageToJavaScript(message); 1373 GetMessageChannel()->PostMessageToJavaScript(message);
1361 } 1374 }
1362 1375
1363 int32_t PepperPluginInstanceImpl::RegisterMessageHandler( 1376 int32_t PepperPluginInstanceImpl::RegisterMessageHandler(
1364 PP_Instance instance, 1377 PP_Instance instance,
1365 void* user_data, 1378 void* user_data,
1366 const PPP_MessageHandler_0_1* handler, 1379 const PPP_MessageHandler_0_1* handler,
1367 PP_Resource message_loop) { 1380 PP_Resource message_loop) {
1368 // Not supported in-process. 1381 // Not supported in-process.
1369 NOTIMPLEMENTED(); 1382 NOTIMPLEMENTED();
1370 return PP_ERROR_FAILED; 1383 return PP_ERROR_FAILED;
(...skipping 980 matching lines...) Expand 10 before | Expand all | Expand 10 after
2351 2364
2352 const ViewData* PepperPluginInstanceImpl::GetViewData(PP_Instance instance) { 2365 const ViewData* PepperPluginInstanceImpl::GetViewData(PP_Instance instance) {
2353 return &view_data_; 2366 return &view_data_;
2354 } 2367 }
2355 2368
2356 PP_Bool PepperPluginInstanceImpl::FlashIsFullscreen(PP_Instance instance) { 2369 PP_Bool PepperPluginInstanceImpl::FlashIsFullscreen(PP_Instance instance) {
2357 return PP_FromBool(flash_fullscreen_); 2370 return PP_FromBool(flash_fullscreen_);
2358 } 2371 }
2359 2372
2360 PP_Var PepperPluginInstanceImpl::GetWindowObject(PP_Instance instance) { 2373 PP_Var PepperPluginInstanceImpl::GetWindowObject(PP_Instance instance) {
2361 if (!container_) 2374 ScopedPPVar script(ScopedPPVar::PassRef(),
2362 return PP_MakeUndefined(); 2375 StringVar::StringToPPVar("window"));
2363 2376 return ExecuteScript(pp_instance(), script.get(), NULL);
Krzysztof Olczyk 2014/08/13 07:13:56 do you really need to execute the script here? Ca
jochen (gone - plz use gerrit) 2014/08/13 14:17:07 +1
raymes 2014/08/14 00:47:57 Thanks! I didn't know how to get at it, but this m
2364 WebLocalFrame* frame = container_->element().document().frame();
2365 if (!frame)
2366 return PP_MakeUndefined();
2367
2368 return NPObjectToPPVar(this, frame->windowObject());
2369 } 2377 }
2370 2378
2371 PP_Var PepperPluginInstanceImpl::GetOwnerElementObject(PP_Instance instance) { 2379 PP_Var PepperPluginInstanceImpl::GetOwnerElementObject(PP_Instance instance) {
2372 if (!container_) 2380 if (!container_)
2373 return PP_MakeUndefined(); 2381 return PP_MakeUndefined();
2374 return NPObjectToPPVar(this, container_->scriptableObjectForElement()); 2382 PepperTryCatchVar try_catch(this, true, NULL);
2383 ScopedPPVar result = try_catch.FromV8(container_->v8ObjectForElement());
2384 DCHECK(!try_catch.HasException());
2385 return result.Release();
2375 } 2386 }
2376 2387
2377 PP_Var PepperPluginInstanceImpl::ExecuteScript(PP_Instance instance, 2388 PP_Var PepperPluginInstanceImpl::ExecuteScript(PP_Instance instance,
2378 PP_Var script, 2389 PP_Var script_var,
2379 PP_Var* exception) { 2390 PP_Var* exception) {
2391 if (!container_)
2392 return PP_MakeUndefined();
2393
2380 // Executing the script may remove the plugin from the DOM, so we need to keep 2394 // Executing the script may remove the plugin from the DOM, so we need to keep
2381 // a reference to ourselves so that we can still process the result after the 2395 // a reference to ourselves so that we can still process the result after the
2382 // WebBindings::evaluate() below. 2396 // WebBindings::evaluate() below.
2383 scoped_refptr<PepperPluginInstanceImpl> ref(this); 2397 scoped_refptr<PepperPluginInstanceImpl> ref(this);
2384 TryCatch try_catch(exception); 2398 PepperTryCatchVar try_catch(this, true, exception);
2385 if (try_catch.has_exception()) 2399 WebLocalFrame* frame = container_->element().document().frame();
2400 if (!frame) {
2401 try_catch.SetException("No frame to execute script in.");
2386 return PP_MakeUndefined(); 2402 return PP_MakeUndefined();
2403 }
2387 2404
2388 // Convert the script into an inconvenient NPString object. 2405 StringVar* script_string_var = StringVar::FromPPVar(script_var);
2389 StringVar* script_string = StringVar::FromPPVar(script); 2406 if (!script_string_var) {
2390 if (!script_string) {
2391 try_catch.SetException("Script param to ExecuteScript must be a string."); 2407 try_catch.SetException("Script param to ExecuteScript must be a string.");
2392 return PP_MakeUndefined(); 2408 return PP_MakeUndefined();
2393 } 2409 }
2394 NPString np_script;
2395 np_script.UTF8Characters = script_string->value().c_str();
2396 np_script.UTF8Length = script_string->value().length();
2397 2410
2398 // Get the current frame to pass to the evaluate function. 2411 std::string script_string = script_string_var->value();
2399 WebLocalFrame* frame = NULL; 2412 blink::WebScriptSource script(
2400 if (container_) 2413 blink::WebString::fromUTF8(script_string.c_str()));
2401 frame = container_->element().document().frame(); 2414 v8::Handle<v8::Value> result;
2402 if (!frame || !frame->windowObject()) { 2415 if (IsProcessingUserGesture()) {
2403 try_catch.SetException("No context in which to execute script."); 2416 blink::WebScopedUserGesture user_gesture(CurrentUserGestureToken());
2404 return PP_MakeUndefined(); 2417 result = frame->executeScriptAndReturnValue(script);
2418 } else {
2419 result = frame->executeScriptAndReturnValue(script);
2405 } 2420 }
2406 2421
2407 NPVariant result; 2422 ScopedPPVar var_result = try_catch.FromV8(result);
2408 bool ok = false; 2423 if (try_catch.HasException())
2409 if (IsProcessingUserGesture()) {
2410 blink::WebScopedUserGesture user_gesture(CurrentUserGestureToken());
2411 ok =
2412 WebBindings::evaluate(NULL, frame->windowObject(), &np_script, &result);
2413 } else {
2414 ok =
2415 WebBindings::evaluate(NULL, frame->windowObject(), &np_script, &result);
2416 }
2417 if (!ok) {
2418 // TryCatch doesn't catch the exceptions properly. Since this is only for
2419 // a trusted API, just set to a general exception message.
2420 try_catch.SetException("Exception caught");
2421 WebBindings::releaseVariantValue(&result);
2422 return PP_MakeUndefined(); 2424 return PP_MakeUndefined();
2423 }
2424 2425
2425 PP_Var ret = NPVariantToPPVar(this, &result); 2426 return var_result.Release();
2426 WebBindings::releaseVariantValue(&result);
2427 return ret;
2428 } 2427 }
2429 2428
2430 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputSampleRate( 2429 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputSampleRate(
2431 PP_Instance instance) { 2430 PP_Instance instance) {
2432 RenderThreadImpl* thread = RenderThreadImpl::current(); 2431 RenderThreadImpl* thread = RenderThreadImpl::current();
2433 return thread->GetAudioHardwareConfig()->GetOutputSampleRate(); 2432 return thread->GetAudioHardwareConfig()->GetOutputSampleRate();
2434 } 2433 }
2435 2434
2436 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputBufferSize( 2435 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputBufferSize(
2437 PP_Instance instance) { 2436 PP_Instance instance) {
(...skipping 508 matching lines...) Expand 10 before | Expand all | Expand 10 after
2946 plugin_selection_interface_ = NULL; 2945 plugin_selection_interface_ = NULL;
2947 plugin_textinput_interface_ = NULL; 2946 plugin_textinput_interface_ = NULL;
2948 plugin_zoom_interface_ = NULL; 2947 plugin_zoom_interface_ = NULL;
2949 2948
2950 // Re-send the DidCreate event via the proxy. 2949 // Re-send the DidCreate event via the proxy.
2951 scoped_ptr<const char * []> argn_array(StringVectorToArgArray(argn_)); 2950 scoped_ptr<const char * []> argn_array(StringVectorToArgArray(argn_));
2952 scoped_ptr<const char * []> argv_array(StringVectorToArgArray(argv_)); 2951 scoped_ptr<const char * []> argv_array(StringVectorToArgArray(argv_));
2953 if (!instance_interface_->DidCreate( 2952 if (!instance_interface_->DidCreate(
2954 pp_instance(), argn_.size(), argn_array.get(), argv_array.get())) 2953 pp_instance(), argn_.size(), argn_array.get(), argv_array.get()))
2955 return PP_EXTERNAL_PLUGIN_ERROR_INSTANCE; 2954 return PP_EXTERNAL_PLUGIN_ERROR_INSTANCE;
2956 message_channel_->Start(); 2955 GetMessageChannel()->Start();
2957 2956
2958 // Clear sent_initial_did_change_view_ and cancel any pending DidChangeView 2957 // Clear sent_initial_did_change_view_ and cancel any pending DidChangeView
2959 // event. This way, SendDidChangeView will send the "current" view 2958 // event. This way, SendDidChangeView will send the "current" view
2960 // immediately (before other events like HandleDocumentLoad). 2959 // immediately (before other events like HandleDocumentLoad).
2961 sent_initial_did_change_view_ = false; 2960 sent_initial_did_change_view_ = false;
2962 view_change_weak_ptr_factory_.InvalidateWeakPtrs(); 2961 view_change_weak_ptr_factory_.InvalidateWeakPtrs();
2963 SendDidChangeView(); 2962 SendDidChangeView();
2964 2963
2965 DCHECK(external_document_load_); 2964 DCHECK(external_document_load_);
2966 external_document_load_ = false; 2965 external_document_load_ = false;
2967 if (!external_document_response_.isNull()) { 2966 if (!external_document_response_.isNull()) {
2968 document_loader_ = NULL; 2967 document_loader_ = NULL;
2969 // Pass the response to the new proxy. 2968 // Pass the response to the new proxy.
2970 HandleDocumentLoad(external_document_response_); 2969 HandleDocumentLoad(external_document_response_);
2971 external_document_response_ = blink::WebURLResponse(); 2970 external_document_response_ = blink::WebURLResponse();
2972 // Replay any document load events we've received to the real loader. 2971 // Replay any document load events we've received to the real loader.
2973 external_document_loader_->ReplayReceivedData(document_loader_); 2972 external_document_loader_->ReplayReceivedData(document_loader_);
2974 external_document_loader_.reset(NULL); 2973 external_document_loader_.reset(NULL);
2975 } 2974 }
2976 2975
2977 return PP_EXTERNAL_PLUGIN_OK; 2976 return PP_EXTERNAL_PLUGIN_OK;
2978 } 2977 }
2979 2978
2980 bool PepperPluginInstanceImpl::IsValidInstanceOf(PluginModule* module) { 2979 bool PepperPluginInstanceImpl::IsValidInstanceOf(PluginModule* module) {
2981 DCHECK(module); 2980 DCHECK(module);
2982 return module == module_.get() || module == original_module_.get(); 2981 return module == module_.get() || module == original_module_.get();
2983 } 2982 }
2984 2983
2985 NPP PepperPluginInstanceImpl::instanceNPP() { return npp_.get(); }
2986
2987 PepperPluginInstance* PepperPluginInstance::Get(PP_Instance instance_id) { 2984 PepperPluginInstance* PepperPluginInstance::Get(PP_Instance instance_id) {
2988 return HostGlobals::Get()->GetInstance(instance_id); 2985 return HostGlobals::Get()->GetInstance(instance_id);
2989 } 2986 }
2990 2987
2991 RenderView* PepperPluginInstanceImpl::GetRenderView() { 2988 RenderView* PepperPluginInstanceImpl::GetRenderView() {
2992 return render_frame_ ? render_frame_->render_view() : NULL; 2989 return render_frame_ ? render_frame_->render_view() : NULL;
2993 } 2990 }
2994 2991
2995 blink::WebPluginContainer* PepperPluginInstanceImpl::GetContainer() { 2992 blink::WebPluginContainer* PepperPluginInstanceImpl::GetContainer() {
2996 return container_; 2993 return container_;
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after
3183 int PepperPluginInstanceImpl::MakePendingFileRefRendererHost( 3180 int PepperPluginInstanceImpl::MakePendingFileRefRendererHost(
3184 const base::FilePath& path) { 3181 const base::FilePath& path) {
3185 RendererPpapiHostImpl* host_impl = module_->renderer_ppapi_host(); 3182 RendererPpapiHostImpl* host_impl = module_->renderer_ppapi_host();
3186 PepperFileRefRendererHost* file_ref_host( 3183 PepperFileRefRendererHost* file_ref_host(
3187 new PepperFileRefRendererHost(host_impl, pp_instance(), 0, path)); 3184 new PepperFileRefRendererHost(host_impl, pp_instance(), 0, path));
3188 return host_impl->GetPpapiHost()->AddPendingResourceHost( 3185 return host_impl->GetPpapiHost()->AddPendingResourceHost(
3189 scoped_ptr<ppapi::host::ResourceHost>(file_ref_host)); 3186 scoped_ptr<ppapi::host::ResourceHost>(file_ref_host));
3190 } 3187 }
3191 3188
3192 void PepperPluginInstanceImpl::SetEmbedProperty(PP_Var key, PP_Var value) { 3189 void PepperPluginInstanceImpl::SetEmbedProperty(PP_Var key, PP_Var value) {
3193 message_channel_->SetReadOnlyProperty(key, value); 3190 GetMessageChannel()->SetReadOnlyProperty(key, value);
3194 } 3191 }
3195 3192
3196 bool PepperPluginInstanceImpl::CanAccessMainFrame() const { 3193 bool PepperPluginInstanceImpl::CanAccessMainFrame() const {
3197 if (!container_) 3194 if (!container_)
3198 return false; 3195 return false;
3199 blink::WebDocument containing_document = container_->element().document(); 3196 blink::WebDocument containing_document = container_->element().document();
3200 3197
3201 if (!containing_document.frame() || !containing_document.frame()->view() || 3198 if (!containing_document.frame() || !containing_document.frame()->view() ||
3202 !containing_document.frame()->view()->mainFrame()) { 3199 !containing_document.frame()->view()->mainFrame()) {
3203 return false; 3200 return false;
(...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after
3320 // Running out-of-process. Initiate an IPC call to notify the plugin 3317 // Running out-of-process. Initiate an IPC call to notify the plugin
3321 // process. 3318 // process.
3322 ppapi::proxy::HostDispatcher* dispatcher = 3319 ppapi::proxy::HostDispatcher* dispatcher =
3323 ppapi::proxy::HostDispatcher::GetForInstance(pp_instance()); 3320 ppapi::proxy::HostDispatcher::GetForInstance(pp_instance());
3324 dispatcher->Send(new PpapiMsg_PPPInstance_HandleDocumentLoad( 3321 dispatcher->Send(new PpapiMsg_PPPInstance_HandleDocumentLoad(
3325 ppapi::API_ID_PPP_INSTANCE, pp_instance(), pending_host_id, data)); 3322 ppapi::API_ID_PPP_INSTANCE, pp_instance(), pending_host_id, data));
3326 } 3323 }
3327 } 3324 }
3328 3325
3329 } // namespace content 3326 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/pepper/pepper_plugin_instance_impl.h ('k') | content/renderer/pepper/pepper_webplugin_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698