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

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

Issue 522583002: Revert of Replace NPObject usage in ppapi with gin (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 3 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/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"
36 #include "content/renderer/pepper/pepper_browser_connection.h" 37 #include "content/renderer/pepper/pepper_browser_connection.h"
37 #include "content/renderer/pepper/pepper_compositor_host.h" 38 #include "content/renderer/pepper/pepper_compositor_host.h"
38 #include "content/renderer/pepper/pepper_file_ref_renderer_host.h" 39 #include "content/renderer/pepper/pepper_file_ref_renderer_host.h"
39 #include "content/renderer/pepper/pepper_graphics_2d_host.h" 40 #include "content/renderer/pepper/pepper_graphics_2d_host.h"
40 #include "content/renderer/pepper/pepper_in_process_router.h" 41 #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"
119 #include "third_party/WebKit/public/web/WebSecurityOrigin.h" 118 #include "third_party/WebKit/public/web/WebSecurityOrigin.h"
120 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h" 119 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h"
121 #include "third_party/WebKit/public/web/WebView.h" 120 #include "third_party/WebKit/public/web/WebView.h"
122 #include "third_party/khronos/GLES2/gl2.h" 121 #include "third_party/khronos/GLES2/gl2.h"
123 #include "third_party/skia/include/core/SkCanvas.h" 122 #include "third_party/skia/include/core/SkCanvas.h"
124 #include "third_party/skia/include/core/SkRect.h" 123 #include "third_party/skia/include/core/SkRect.h"
125 #include "ui/gfx/image/image_skia.h" 124 #include "ui/gfx/image/image_skia.h"
126 #include "ui/gfx/image/image_skia_rep.h" 125 #include "ui/gfx/image/image_skia_rep.h"
127 #include "ui/gfx/range/range.h" 126 #include "ui/gfx/range/range.h"
128 #include "ui/gfx/rect_conversions.h" 127 #include "ui/gfx/rect_conversions.h"
(...skipping 424 matching lines...) Expand 10 before | Expand all | Expand 10 after
553 filtered_input_event_mask_(0), 552 filtered_input_event_mask_(0),
554 text_input_type_(kPluginDefaultTextInputType), 553 text_input_type_(kPluginDefaultTextInputType),
555 text_input_caret_(0, 0, 0, 0), 554 text_input_caret_(0, 0, 0, 0),
556 text_input_caret_bounds_(0, 0, 0, 0), 555 text_input_caret_bounds_(0, 0, 0, 0),
557 text_input_caret_set_(false), 556 text_input_caret_set_(false),
558 selection_caret_(0), 557 selection_caret_(0),
559 selection_anchor_(0), 558 selection_anchor_(0),
560 pending_user_gesture_(0.0), 559 pending_user_gesture_(0.0),
561 document_loader_(NULL), 560 document_loader_(NULL),
562 external_document_load_(false), 561 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 // Notify all the plugin objects of deletion. This will prevent blink from 623 // Free all the plugin objects. This will automatically clear the back-
624 // calling into the plugin any more. 624 // pointer from the NPObject so WebKit can't call into the plugin any more.
625 // 625 //
626 // Swap out the set so we can delete from it (the objects will try to 626 // Swap out the set so we can delete from it (the objects will try to
627 // unregister themselves inside the delete call). 627 // unregister themselves inside the delete call).
628 PluginObjectSet plugin_object_copy; 628 PluginObjectSet plugin_object_copy;
629 live_plugin_objects_.swap(plugin_object_copy); 629 live_plugin_objects_.swap(plugin_object_copy);
630 for (PluginObjectSet::iterator i = plugin_object_copy.begin(); 630 for (PluginObjectSet::iterator i = plugin_object_copy.begin();
631 i != plugin_object_copy.end(); 631 i != plugin_object_copy.end();
632 ++i) { 632 ++i)
633 (*i)->InstanceDeleted(); 633 delete *i;
634 }
635
636 if (message_channel_) {
637 message_channel_->InstanceDeleted();
638 message_channel_object_.Reset();
639 message_channel_ = NULL;
640 }
641 634
642 if (TrackedCallback::IsPending(lock_mouse_callback_)) 635 if (TrackedCallback::IsPending(lock_mouse_callback_))
643 lock_mouse_callback_->Abort(); 636 lock_mouse_callback_->Abort();
644 637
645 if (!instance_deleted_callback_.is_null()) 638 if (!instance_deleted_callback_.is_null())
646 instance_deleted_callback_.Run(); 639 instance_deleted_callback_.Run();
647 640
648 if (!module_->IsProxied() && render_frame_) { 641 if (!module_->IsProxied() && render_frame_) {
649 PepperBrowserConnection* browser_connection = 642 PepperBrowserConnection* browser_connection =
650 PepperBrowserConnection::Get(render_frame_); 643 PepperBrowserConnection::Get(render_frame_);
(...skipping 10 matching lines...) Expand all
661 // want to look up in the global map to get info off of our object. 654 // want to look up in the global map to get info off of our object.
662 HostGlobals::Get()->InstanceDeleted(pp_instance_); 655 HostGlobals::Get()->InstanceDeleted(pp_instance_);
663 } 656 }
664 657
665 // NOTE: Any of these methods that calls into the plugin needs to take into 658 // NOTE: Any of these methods that calls into the plugin needs to take into
666 // account that the plugin may use Var to remove the <embed> from the DOM, which 659 // account that the plugin may use Var to remove the <embed> from the DOM, which
667 // will make the PepperWebPluginImpl drop its reference, usually the last one. 660 // will make the PepperWebPluginImpl drop its reference, usually the last one.
668 // If a method needs to access a member of the instance after the call has 661 // If a method needs to access a member of the instance after the call has
669 // returned, then it needs to keep its own reference on the stack. 662 // returned, then it needs to keep its own reference on the stack.
670 663
671 v8::Local<v8::Object> PepperPluginInstanceImpl::GetMessageChannelObject() {
672 return v8::Local<v8::Object>::New(isolate_, message_channel_object_);
673 }
674
675 v8::Local<v8::Context> PepperPluginInstanceImpl::GetContext() { 664 v8::Local<v8::Context> PepperPluginInstanceImpl::GetContext() {
676 if (!container_) 665 if (!container_)
677 return v8::Handle<v8::Context>(); 666 return v8::Handle<v8::Context>();
678 WebLocalFrame* frame = container_->element().document().frame(); 667 WebLocalFrame* frame = container_->element().document().frame();
679 if (!frame) 668 if (!frame)
680 return v8::Handle<v8::Context>(); 669 return v8::Handle<v8::Context>();
681 670
682 v8::Local<v8::Context> context = frame->mainWorldScriptContext(); 671 v8::Local<v8::Context> context = frame->mainWorldScriptContext();
683 DCHECK(context->GetIsolate() == isolate_); 672 DCHECK(context->GetIsolate() == isolate_);
684 return context; 673 return context;
685 } 674 }
686 675
687 void PepperPluginInstanceImpl::Delete() { 676 void PepperPluginInstanceImpl::Delete() {
688 is_deleted_ = true; 677 is_deleted_ = true;
689 678
690 if (render_frame_ && 679 if (render_frame_ &&
691 render_frame_->render_view()->plugin_find_handler() == this) { 680 render_frame_->render_view()->plugin_find_handler() == this) {
692 render_frame_->render_view()->set_plugin_find_handler(NULL); 681 render_frame_->render_view()->set_plugin_find_handler(NULL);
693 } 682 }
694 683
695 // Keep a reference on the stack. See NOTE above. 684 // Keep a reference on the stack. See NOTE above.
696 scoped_refptr<PepperPluginInstanceImpl> ref(this); 685 scoped_refptr<PepperPluginInstanceImpl> ref(this);
697 // Force the MessageChannel to release its "passthrough object" which should 686 // Force the MessageChannel to release its "passthrough object" which should
698 // release our last reference to the "InstanceObject" and will probably 687 // release our last reference to the "InstanceObject" and will probably
699 // destroy it. We want to do this prior to calling DidDestroy in case the 688 // destroy it. We want to do this prior to calling DidDestroy in case the
700 // destructor of the instance object tries to use the instance. 689 // destructor of the instance object tries to use the instance.
701 message_channel_->SetPassthroughObject(v8::Handle<v8::Object>()); 690 message_channel_->SetPassthroughObject(NULL);
702 // If this is a NaCl plugin instance, shut down the NaCl plugin by calling 691 // If this is a NaCl plugin instance, shut down the NaCl plugin by calling
703 // its DidDestroy. Don't call DidDestroy on the untrusted plugin instance, 692 // its DidDestroy. Don't call DidDestroy on the untrusted plugin instance,
704 // since there is little that it can do at this point. 693 // since there is little that it can do at this point.
705 if (original_instance_interface_) 694 if (original_instance_interface_)
706 original_instance_interface_->DidDestroy(pp_instance()); 695 original_instance_interface_->DidDestroy(pp_instance());
707 else 696 else
708 instance_interface_->DidDestroy(pp_instance()); 697 instance_interface_->DidDestroy(pp_instance());
709 // Ensure we don't attempt to call functions on the destroyed instance. 698 // Ensure we don't attempt to call functions on the destroyed instance.
710 original_instance_interface_.reset(); 699 original_instance_interface_.reset();
711 instance_interface_.reset(); 700 instance_interface_.reset();
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after
853 "Flash.UsesGPU", is_xp * 4 + needs_gpu * 2 + prefs.is_webgl_supported, 8); 842 "Flash.UsesGPU", is_xp * 4 + needs_gpu * 2 + prefs.is_webgl_supported, 8);
854 #endif 843 #endif
855 } 844 }
856 845
857 bool PepperPluginInstanceImpl::Initialize( 846 bool PepperPluginInstanceImpl::Initialize(
858 const std::vector<std::string>& arg_names, 847 const std::vector<std::string>& arg_names,
859 const std::vector<std::string>& arg_values, 848 const std::vector<std::string>& arg_values,
860 bool full_frame) { 849 bool full_frame) {
861 if (!render_frame_) 850 if (!render_frame_)
862 return false; 851 return false;
863 message_channel_ = MessageChannel::Create(this, &message_channel_object_); 852 message_channel_.reset(new MessageChannel(this));
864 853
865 full_frame_ = full_frame; 854 full_frame_ = full_frame;
866 855
867 UpdateTouchEventRequest(); 856 UpdateTouchEventRequest();
868 container_->setWantsWheelEvents(IsAcceptingWheelEvents()); 857 container_->setWantsWheelEvents(IsAcceptingWheelEvents());
869 858
870 SetGPUHistogram(ppapi::Preferences(PpapiPreferencesBuilder::Build( 859 SetGPUHistogram(ppapi::Preferences(PpapiPreferencesBuilder::Build(
871 render_frame_->render_view()->webkit_preferences())), 860 render_frame_->render_view()->webkit_preferences())),
872 arg_names, 861 arg_names,
873 arg_values); 862 arg_values);
(...skipping 348 matching lines...) Expand 10 before | Expand all | Expand 10 after
1222 ppapi::proxy::SerializedVarSendInputShmem(dispatcher, message.get(), 1211 ppapi::proxy::SerializedVarSendInputShmem(dispatcher, message.get(),
1223 pp_instance()), 1212 pp_instance()),
1224 &msg_reply, 1213 &msg_reply,
1225 &was_handled)); 1214 &was_handled));
1226 *result = ScopedPPVar(ScopedPPVar::PassRef(), msg_reply.Return(dispatcher)); 1215 *result = ScopedPPVar(ScopedPPVar::PassRef(), msg_reply.Return(dispatcher));
1227 TRACE_EVENT0("ppapi", 1216 TRACE_EVENT0("ppapi",
1228 "PepperPluginInstanceImpl::HandleBlockingMessage return."); 1217 "PepperPluginInstanceImpl::HandleBlockingMessage return.");
1229 return was_handled; 1218 return was_handled;
1230 } 1219 }
1231 1220
1232 PP_Var PepperPluginInstanceImpl::GetInstanceObject(v8::Isolate* isolate) { 1221 PP_Var PepperPluginInstanceImpl::GetInstanceObject() {
1233 // Keep a reference on the stack. See NOTE above. 1222 // Keep a reference on the stack. See NOTE above.
1234 scoped_refptr<PepperPluginInstanceImpl> ref(this); 1223 scoped_refptr<PepperPluginInstanceImpl> ref(this);
1235 1224
1236 DCHECK_EQ(isolate, isolate_);
1237
1238 // If the plugin supports the private instance interface, try to retrieve its 1225 // If the plugin supports the private instance interface, try to retrieve its
1239 // instance object. 1226 // instance object.
1240 if (LoadPrivateInterface()) 1227 if (LoadPrivateInterface())
1241 return plugin_private_interface_->GetInstanceObject(pp_instance()); 1228 return plugin_private_interface_->GetInstanceObject(pp_instance());
1242 return PP_MakeUndefined(); 1229 return PP_MakeUndefined();
1243 } 1230 }
1244 1231
1245 void PepperPluginInstanceImpl::ViewChanged( 1232 void PepperPluginInstanceImpl::ViewChanged(
1246 const gfx::Rect& position, 1233 const gfx::Rect& position,
1247 const gfx::Rect& clip, 1234 const gfx::Rect& clip,
(...skipping 1118 matching lines...) Expand 10 before | Expand all | Expand 10 after
2366 } 2353 }
2367 2354
2368 PP_Bool PepperPluginInstanceImpl::FlashIsFullscreen(PP_Instance instance) { 2355 PP_Bool PepperPluginInstanceImpl::FlashIsFullscreen(PP_Instance instance) {
2369 return PP_FromBool(flash_fullscreen_); 2356 return PP_FromBool(flash_fullscreen_);
2370 } 2357 }
2371 2358
2372 PP_Var PepperPluginInstanceImpl::GetWindowObject(PP_Instance instance) { 2359 PP_Var PepperPluginInstanceImpl::GetWindowObject(PP_Instance instance) {
2373 if (!container_) 2360 if (!container_)
2374 return PP_MakeUndefined(); 2361 return PP_MakeUndefined();
2375 2362
2376 PepperTryCatchVar try_catch(this, NULL);
2377 WebLocalFrame* frame = container_->element().document().frame(); 2363 WebLocalFrame* frame = container_->element().document().frame();
2378 if (!frame) { 2364 if (!frame)
2379 try_catch.SetException("No frame exists for window object.");
2380 return PP_MakeUndefined(); 2365 return PP_MakeUndefined();
2381 }
2382 2366
2383 ScopedPPVar result = 2367 return NPObjectToPPVar(this, frame->windowObject());
2384 try_catch.FromV8(frame->mainWorldScriptContext()->Global());
2385 DCHECK(!try_catch.HasException());
2386 return result.Release();
2387 } 2368 }
2388 2369
2389 PP_Var PepperPluginInstanceImpl::GetOwnerElementObject(PP_Instance instance) { 2370 PP_Var PepperPluginInstanceImpl::GetOwnerElementObject(PP_Instance instance) {
2390 if (!container_) 2371 if (!container_)
2391 return PP_MakeUndefined(); 2372 return PP_MakeUndefined();
2392 PepperTryCatchVar try_catch(this, NULL); 2373 return NPObjectToPPVar(this, container_->scriptableObjectForElement());
2393 ScopedPPVar result = try_catch.FromV8(container_->v8ObjectForElement());
2394 DCHECK(!try_catch.HasException());
2395 return result.Release();
2396 } 2374 }
2397 2375
2398 PP_Var PepperPluginInstanceImpl::ExecuteScript(PP_Instance instance, 2376 PP_Var PepperPluginInstanceImpl::ExecuteScript(PP_Instance instance,
2399 PP_Var script_var, 2377 PP_Var script,
2400 PP_Var* exception) { 2378 PP_Var* exception) {
2401 if (!container_)
2402 return PP_MakeUndefined();
2403
2404 // Executing the script may remove the plugin from the DOM, so we need to keep 2379 // Executing the script may remove the plugin from the DOM, so we need to keep
2405 // a reference to ourselves so that we can still process the result after the 2380 // a reference to ourselves so that we can still process the result after the
2406 // WebBindings::evaluate() below. 2381 // WebBindings::evaluate() below.
2407 scoped_refptr<PepperPluginInstanceImpl> ref(this); 2382 scoped_refptr<PepperPluginInstanceImpl> ref(this);
2408 PepperTryCatchVar try_catch(this, exception); 2383 TryCatch try_catch(exception);
2409 WebLocalFrame* frame = container_->element().document().frame(); 2384 if (try_catch.has_exception())
2410 if (!frame) { 2385 return PP_MakeUndefined();
2411 try_catch.SetException("No frame to execute script in."); 2386
2387 // Convert the script into an inconvenient NPString object.
2388 StringVar* script_string = StringVar::FromPPVar(script);
2389 if (!script_string) {
2390 try_catch.SetException("Script param to ExecuteScript must be a string.");
2391 return PP_MakeUndefined();
2392 }
2393 NPString np_script;
2394 np_script.UTF8Characters = script_string->value().c_str();
2395 np_script.UTF8Length = script_string->value().length();
2396
2397 // Get the current frame to pass to the evaluate function.
2398 WebLocalFrame* frame = NULL;
2399 if (container_)
2400 frame = container_->element().document().frame();
2401 if (!frame || !frame->windowObject()) {
2402 try_catch.SetException("No context in which to execute script.");
2412 return PP_MakeUndefined(); 2403 return PP_MakeUndefined();
2413 } 2404 }
2414 2405
2415 StringVar* script_string_var = StringVar::FromPPVar(script_var); 2406 NPVariant result;
2416 if (!script_string_var) { 2407 bool ok = false;
2417 try_catch.SetException("Script param to ExecuteScript must be a string."); 2408 if (IsProcessingUserGesture()) {
2409 blink::WebScopedUserGesture user_gesture(CurrentUserGestureToken());
2410 ok =
2411 WebBindings::evaluate(NULL, frame->windowObject(), &np_script, &result);
2412 } else {
2413 ok =
2414 WebBindings::evaluate(NULL, frame->windowObject(), &np_script, &result);
2415 }
2416 if (!ok) {
2417 // TryCatch doesn't catch the exceptions properly. Since this is only for
2418 // a trusted API, just set to a general exception message.
2419 try_catch.SetException("Exception caught");
2420 WebBindings::releaseVariantValue(&result);
2418 return PP_MakeUndefined(); 2421 return PP_MakeUndefined();
2419 } 2422 }
2420 2423
2421 std::string script_string = script_string_var->value(); 2424 PP_Var ret = NPVariantToPPVar(this, &result);
2422 blink::WebScriptSource script( 2425 WebBindings::releaseVariantValue(&result);
2423 blink::WebString::fromUTF8(script_string.c_str())); 2426 return ret;
2424 v8::Handle<v8::Value> result;
2425 if (IsProcessingUserGesture()) {
2426 blink::WebScopedUserGesture user_gesture(CurrentUserGestureToken());
2427 result = frame->executeScriptAndReturnValue(script);
2428 } else {
2429 result = frame->executeScriptAndReturnValue(script);
2430 }
2431
2432 ScopedPPVar var_result = try_catch.FromV8(result);
2433 if (try_catch.HasException())
2434 return PP_MakeUndefined();
2435
2436 return var_result.Release();
2437 } 2427 }
2438 2428
2439 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputSampleRate( 2429 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputSampleRate(
2440 PP_Instance instance) { 2430 PP_Instance instance) {
2441 RenderThreadImpl* thread = RenderThreadImpl::current(); 2431 RenderThreadImpl* thread = RenderThreadImpl::current();
2442 return thread->GetAudioHardwareConfig()->GetOutputSampleRate(); 2432 return thread->GetAudioHardwareConfig()->GetOutputSampleRate();
2443 } 2433 }
2444 2434
2445 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputBufferSize( 2435 uint32_t PepperPluginInstanceImpl::GetAudioHardwareOutputBufferSize(
2446 PP_Instance instance) { 2436 PP_Instance instance) {
(...skipping 537 matching lines...) Expand 10 before | Expand all | Expand 10 after
2984 } 2974 }
2985 2975
2986 return PP_EXTERNAL_PLUGIN_OK; 2976 return PP_EXTERNAL_PLUGIN_OK;
2987 } 2977 }
2988 2978
2989 bool PepperPluginInstanceImpl::IsValidInstanceOf(PluginModule* module) { 2979 bool PepperPluginInstanceImpl::IsValidInstanceOf(PluginModule* module) {
2990 DCHECK(module); 2980 DCHECK(module);
2991 return module == module_.get() || module == original_module_.get(); 2981 return module == module_.get() || module == original_module_.get();
2992 } 2982 }
2993 2983
2984 NPP PepperPluginInstanceImpl::instanceNPP() { return npp_.get(); }
2985
2994 PepperPluginInstance* PepperPluginInstance::Get(PP_Instance instance_id) { 2986 PepperPluginInstance* PepperPluginInstance::Get(PP_Instance instance_id) {
2995 return HostGlobals::Get()->GetInstance(instance_id); 2987 return HostGlobals::Get()->GetInstance(instance_id);
2996 } 2988 }
2997 2989
2998 RenderView* PepperPluginInstanceImpl::GetRenderView() { 2990 RenderView* PepperPluginInstanceImpl::GetRenderView() {
2999 return render_frame_ ? render_frame_->render_view() : NULL; 2991 return render_frame_ ? render_frame_->render_view() : NULL;
3000 } 2992 }
3001 2993
3002 blink::WebPluginContainer* PepperPluginInstanceImpl::GetContainer() { 2994 blink::WebPluginContainer* PepperPluginInstanceImpl::GetContainer() {
3003 return container_; 2995 return container_;
(...skipping 323 matching lines...) Expand 10 before | Expand all | Expand 10 after
3327 // Running out-of-process. Initiate an IPC call to notify the plugin 3319 // Running out-of-process. Initiate an IPC call to notify the plugin
3328 // process. 3320 // process.
3329 ppapi::proxy::HostDispatcher* dispatcher = 3321 ppapi::proxy::HostDispatcher* dispatcher =
3330 ppapi::proxy::HostDispatcher::GetForInstance(pp_instance()); 3322 ppapi::proxy::HostDispatcher::GetForInstance(pp_instance());
3331 dispatcher->Send(new PpapiMsg_PPPInstance_HandleDocumentLoad( 3323 dispatcher->Send(new PpapiMsg_PPPInstance_HandleDocumentLoad(
3332 ppapi::API_ID_PPP_INSTANCE, pp_instance(), pending_host_id, data)); 3324 ppapi::API_ID_PPP_INSTANCE, pp_instance(), pending_host_id, data));
3333 } 3325 }
3334 } 3326 }
3335 3327
3336 } // namespace content 3328 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/pepper/pepper_plugin_instance_impl.h ('k') | content/renderer/pepper/pepper_try_catch.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698