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/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 Loading... | |
26 #include "content/public/common/page_zoom.h" | 26 #include "content/public/common/page_zoom.h" |
27 #include "content/public/renderer/content_renderer_client.h" | 27 #include "content/public/renderer/content_renderer_client.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 Loading... | |
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 Loading... | |
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(¤t_print_settings_, 0, sizeof(current_print_settings_)); | 571 memset(¤t_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 Loading... | |
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 |
dmichael (off chromium)
2014/08/21 22:24:24
s/WebKit/blink ?
raymes
2014/08/22 08:28:40
Done.
| |
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). | |
dmichael (off chromium)
2014/08/21 22:24:24
If this comment is still true, I think we should k
raymes
2014/08/22 08:28:40
Done.
| |
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 Loading... | |
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() { | |
dmichael (off chromium)
2014/08/21 22:24:24
Would it be simpler to have PepperPluginInstanceIm
raymes
2014/08/22 08:28:40
Not completely sure what you mean. We need to stor
dmichael (off chromium)
2014/08/22 16:28:46
That's all I meant, is I think it makes sense to *
raymes
2014/08/25 01:40:00
Done.
| |
667 MessageChannel* message_channel = NULL; | |
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 Loading... | |
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_); |
dmichael (off chromium)
2014/08/21 22:24:24
Curious why this doesn't just return the handle? D
raymes
2014/08/22 08:28:40
Ok that sounds reasonable, I'll revisit it in the
| |
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 Loading... | |
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_EQ(isolate, isolate_); | |
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 Loading... | |
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 983 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
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 if (!container_) |
2362 return PP_MakeUndefined(); | 2375 return PP_MakeUndefined(); |
2363 | 2376 |
2377 PepperTryCatchVar try_catch(this, true, NULL); | |
2364 WebLocalFrame* frame = container_->element().document().frame(); | 2378 WebLocalFrame* frame = container_->element().document().frame(); |
2365 if (!frame) | 2379 if (!frame) { |
2380 try_catch.SetException("No frame exists for window object."); | |
2366 return PP_MakeUndefined(); | 2381 return PP_MakeUndefined(); |
2382 } | |
2367 | 2383 |
2368 return NPObjectToPPVar(this, frame->windowObject()); | 2384 ScopedPPVar result = |
2385 try_catch.FromV8(frame->mainWorldScriptContext()->Global()); | |
2386 DCHECK(!try_catch.HasException()); | |
2387 return result.Release(); | |
2369 } | 2388 } |
2370 | 2389 |
2371 PP_Var PepperPluginInstanceImpl::GetOwnerElementObject(PP_Instance instance) { | 2390 PP_Var PepperPluginInstanceImpl::GetOwnerElementObject(PP_Instance instance) { |
2372 if (!container_) | 2391 if (!container_) |
2373 return PP_MakeUndefined(); | 2392 return PP_MakeUndefined(); |
2374 return NPObjectToPPVar(this, container_->scriptableObjectForElement()); | 2393 PepperTryCatchVar try_catch(this, true, NULL); |
dmichael (off chromium)
2014/08/21 22:24:24
optional nit: Stuff like "true" and NULL in callsi
raymes
2014/08/22 08:28:40
Done.
| |
2394 ScopedPPVar result = try_catch.FromV8(container_->v8ObjectForElement()); | |
2395 DCHECK(!try_catch.HasException()); | |
2396 return result.Release(); | |
2375 } | 2397 } |
2376 | 2398 |
2377 PP_Var PepperPluginInstanceImpl::ExecuteScript(PP_Instance instance, | 2399 PP_Var PepperPluginInstanceImpl::ExecuteScript(PP_Instance instance, |
2378 PP_Var script, | 2400 PP_Var script_var, |
2379 PP_Var* exception) { | 2401 PP_Var* exception) { |
2402 if (!container_) | |
2403 return PP_MakeUndefined(); | |
2404 | |
2380 // Executing the script may remove the plugin from the DOM, so we need to keep | 2405 // 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 | 2406 // a reference to ourselves so that we can still process the result after the |
2382 // WebBindings::evaluate() below. | 2407 // WebBindings::evaluate() below. |
2383 scoped_refptr<PepperPluginInstanceImpl> ref(this); | 2408 scoped_refptr<PepperPluginInstanceImpl> ref(this); |
2384 TryCatch try_catch(exception); | 2409 PepperTryCatchVar try_catch(this, true, exception); |
2385 if (try_catch.has_exception()) | 2410 WebLocalFrame* frame = container_->element().document().frame(); |
2411 if (!frame) { | |
2412 try_catch.SetException("No frame to execute script in."); | |
2386 return PP_MakeUndefined(); | 2413 return PP_MakeUndefined(); |
2414 } | |
2387 | 2415 |
2388 // Convert the script into an inconvenient NPString object. | 2416 StringVar* script_string_var = StringVar::FromPPVar(script_var); |
2389 StringVar* script_string = StringVar::FromPPVar(script); | 2417 if (!script_string_var) { |
2390 if (!script_string) { | |
2391 try_catch.SetException("Script param to ExecuteScript must be a string."); | 2418 try_catch.SetException("Script param to ExecuteScript must be a string."); |
2392 return PP_MakeUndefined(); | 2419 return PP_MakeUndefined(); |
2393 } | 2420 } |
2394 NPString np_script; | |
2395 np_script.UTF8Characters = script_string->value().c_str(); | |
2396 np_script.UTF8Length = script_string->value().length(); | |
2397 | 2421 |
2398 // Get the current frame to pass to the evaluate function. | 2422 std::string script_string = script_string_var->value(); |
2399 WebLocalFrame* frame = NULL; | 2423 blink::WebScriptSource script( |
2400 if (container_) | 2424 blink::WebString::fromUTF8(script_string.c_str())); |
2401 frame = container_->element().document().frame(); | 2425 v8::Handle<v8::Value> result; |
2402 if (!frame || !frame->windowObject()) { | 2426 if (IsProcessingUserGesture()) { |
2403 try_catch.SetException("No context in which to execute script."); | 2427 blink::WebScopedUserGesture user_gesture(CurrentUserGestureToken()); |
2404 return PP_MakeUndefined(); | 2428 result = frame->executeScriptAndReturnValue(script); |
2429 } else { | |
2430 result = frame->executeScriptAndReturnValue(script); | |
2405 } | 2431 } |
2406 | 2432 |
2407 NPVariant result; | 2433 ScopedPPVar var_result = try_catch.FromV8(result); |
2408 bool ok = false; | 2434 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(); | 2435 return PP_MakeUndefined(); |
2423 } | |
2424 | 2436 |
2425 PP_Var ret = NPVariantToPPVar(this, &result); | 2437 return var_result.Release(); |
2426 WebBindings::releaseVariantValue(&result); | |
2427 return ret; | |
2428 } | 2438 } |
2429 | 2439 |
2430 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputSampleRate( | 2440 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputSampleRate( |
2431 PP_Instance instance) { | 2441 PP_Instance instance) { |
2432 RenderThreadImpl* thread = RenderThreadImpl::current(); | 2442 RenderThreadImpl* thread = RenderThreadImpl::current(); |
2433 return thread->GetAudioHardwareConfig()->GetOutputSampleRate(); | 2443 return thread->GetAudioHardwareConfig()->GetOutputSampleRate(); |
2434 } | 2444 } |
2435 | 2445 |
2436 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputBufferSize( | 2446 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputBufferSize( |
2437 PP_Instance instance) { | 2447 PP_Instance instance) { |
(...skipping 508 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2946 plugin_selection_interface_ = NULL; | 2956 plugin_selection_interface_ = NULL; |
2947 plugin_textinput_interface_ = NULL; | 2957 plugin_textinput_interface_ = NULL; |
2948 plugin_zoom_interface_ = NULL; | 2958 plugin_zoom_interface_ = NULL; |
2949 | 2959 |
2950 // Re-send the DidCreate event via the proxy. | 2960 // Re-send the DidCreate event via the proxy. |
2951 scoped_ptr<const char * []> argn_array(StringVectorToArgArray(argn_)); | 2961 scoped_ptr<const char * []> argn_array(StringVectorToArgArray(argn_)); |
2952 scoped_ptr<const char * []> argv_array(StringVectorToArgArray(argv_)); | 2962 scoped_ptr<const char * []> argv_array(StringVectorToArgArray(argv_)); |
2953 if (!instance_interface_->DidCreate( | 2963 if (!instance_interface_->DidCreate( |
2954 pp_instance(), argn_.size(), argn_array.get(), argv_array.get())) | 2964 pp_instance(), argn_.size(), argn_array.get(), argv_array.get())) |
2955 return PP_EXTERNAL_PLUGIN_ERROR_INSTANCE; | 2965 return PP_EXTERNAL_PLUGIN_ERROR_INSTANCE; |
2956 message_channel_->Start(); | 2966 GetMessageChannel()->Start(); |
2957 | 2967 |
2958 // Clear sent_initial_did_change_view_ and cancel any pending DidChangeView | 2968 // Clear sent_initial_did_change_view_ and cancel any pending DidChangeView |
2959 // event. This way, SendDidChangeView will send the "current" view | 2969 // event. This way, SendDidChangeView will send the "current" view |
2960 // immediately (before other events like HandleDocumentLoad). | 2970 // immediately (before other events like HandleDocumentLoad). |
2961 sent_initial_did_change_view_ = false; | 2971 sent_initial_did_change_view_ = false; |
2962 view_change_weak_ptr_factory_.InvalidateWeakPtrs(); | 2972 view_change_weak_ptr_factory_.InvalidateWeakPtrs(); |
2963 SendDidChangeView(); | 2973 SendDidChangeView(); |
2964 | 2974 |
2965 DCHECK(external_document_load_); | 2975 DCHECK(external_document_load_); |
2966 external_document_load_ = false; | 2976 external_document_load_ = false; |
2967 if (!external_document_response_.isNull()) { | 2977 if (!external_document_response_.isNull()) { |
2968 document_loader_ = NULL; | 2978 document_loader_ = NULL; |
2969 // Pass the response to the new proxy. | 2979 // Pass the response to the new proxy. |
2970 HandleDocumentLoad(external_document_response_); | 2980 HandleDocumentLoad(external_document_response_); |
2971 external_document_response_ = blink::WebURLResponse(); | 2981 external_document_response_ = blink::WebURLResponse(); |
2972 // Replay any document load events we've received to the real loader. | 2982 // Replay any document load events we've received to the real loader. |
2973 external_document_loader_->ReplayReceivedData(document_loader_); | 2983 external_document_loader_->ReplayReceivedData(document_loader_); |
2974 external_document_loader_.reset(NULL); | 2984 external_document_loader_.reset(NULL); |
2975 } | 2985 } |
2976 | 2986 |
2977 return PP_EXTERNAL_PLUGIN_OK; | 2987 return PP_EXTERNAL_PLUGIN_OK; |
2978 } | 2988 } |
2979 | 2989 |
2980 bool PepperPluginInstanceImpl::IsValidInstanceOf(PluginModule* module) { | 2990 bool PepperPluginInstanceImpl::IsValidInstanceOf(PluginModule* module) { |
2981 DCHECK(module); | 2991 DCHECK(module); |
2982 return module == module_.get() || module == original_module_.get(); | 2992 return module == module_.get() || module == original_module_.get(); |
2983 } | 2993 } |
2984 | 2994 |
2985 NPP PepperPluginInstanceImpl::instanceNPP() { return npp_.get(); } | |
2986 | |
2987 PepperPluginInstance* PepperPluginInstance::Get(PP_Instance instance_id) { | 2995 PepperPluginInstance* PepperPluginInstance::Get(PP_Instance instance_id) { |
2988 return HostGlobals::Get()->GetInstance(instance_id); | 2996 return HostGlobals::Get()->GetInstance(instance_id); |
2989 } | 2997 } |
2990 | 2998 |
2991 RenderView* PepperPluginInstanceImpl::GetRenderView() { | 2999 RenderView* PepperPluginInstanceImpl::GetRenderView() { |
2992 return render_frame_ ? render_frame_->render_view() : NULL; | 3000 return render_frame_ ? render_frame_->render_view() : NULL; |
2993 } | 3001 } |
2994 | 3002 |
2995 blink::WebPluginContainer* PepperPluginInstanceImpl::GetContainer() { | 3003 blink::WebPluginContainer* PepperPluginInstanceImpl::GetContainer() { |
2996 return container_; | 3004 return container_; |
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
3183 int PepperPluginInstanceImpl::MakePendingFileRefRendererHost( | 3191 int PepperPluginInstanceImpl::MakePendingFileRefRendererHost( |
3184 const base::FilePath& path) { | 3192 const base::FilePath& path) { |
3185 RendererPpapiHostImpl* host_impl = module_->renderer_ppapi_host(); | 3193 RendererPpapiHostImpl* host_impl = module_->renderer_ppapi_host(); |
3186 PepperFileRefRendererHost* file_ref_host( | 3194 PepperFileRefRendererHost* file_ref_host( |
3187 new PepperFileRefRendererHost(host_impl, pp_instance(), 0, path)); | 3195 new PepperFileRefRendererHost(host_impl, pp_instance(), 0, path)); |
3188 return host_impl->GetPpapiHost()->AddPendingResourceHost( | 3196 return host_impl->GetPpapiHost()->AddPendingResourceHost( |
3189 scoped_ptr<ppapi::host::ResourceHost>(file_ref_host)); | 3197 scoped_ptr<ppapi::host::ResourceHost>(file_ref_host)); |
3190 } | 3198 } |
3191 | 3199 |
3192 void PepperPluginInstanceImpl::SetEmbedProperty(PP_Var key, PP_Var value) { | 3200 void PepperPluginInstanceImpl::SetEmbedProperty(PP_Var key, PP_Var value) { |
3193 message_channel_->SetReadOnlyProperty(key, value); | 3201 GetMessageChannel()->SetReadOnlyProperty(key, value); |
3194 } | 3202 } |
3195 | 3203 |
3196 bool PepperPluginInstanceImpl::CanAccessMainFrame() const { | 3204 bool PepperPluginInstanceImpl::CanAccessMainFrame() const { |
3197 if (!container_) | 3205 if (!container_) |
3198 return false; | 3206 return false; |
3199 blink::WebDocument containing_document = container_->element().document(); | 3207 blink::WebDocument containing_document = container_->element().document(); |
3200 | 3208 |
3201 if (!containing_document.frame() || !containing_document.frame()->view() || | 3209 if (!containing_document.frame() || !containing_document.frame()->view() || |
3202 !containing_document.frame()->view()->mainFrame()) { | 3210 !containing_document.frame()->view()->mainFrame()) { |
3203 return false; | 3211 return false; |
(...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
3320 // Running out-of-process. Initiate an IPC call to notify the plugin | 3328 // Running out-of-process. Initiate an IPC call to notify the plugin |
3321 // process. | 3329 // process. |
3322 ppapi::proxy::HostDispatcher* dispatcher = | 3330 ppapi::proxy::HostDispatcher* dispatcher = |
3323 ppapi::proxy::HostDispatcher::GetForInstance(pp_instance()); | 3331 ppapi::proxy::HostDispatcher::GetForInstance(pp_instance()); |
3324 dispatcher->Send(new PpapiMsg_PPPInstance_HandleDocumentLoad( | 3332 dispatcher->Send(new PpapiMsg_PPPInstance_HandleDocumentLoad( |
3325 ppapi::API_ID_PPP_INSTANCE, pp_instance(), pending_host_id, data)); | 3333 ppapi::API_ID_PPP_INSTANCE, pp_instance(), pending_host_id, data)); |
3326 } | 3334 } |
3327 } | 3335 } |
3328 | 3336 |
3329 } // namespace content | 3337 } // namespace content |
OLD | NEW |