| Index: content/renderer/pepper/content_renderer_pepper_host_factory.cc
|
| diff --git a/content/renderer/pepper/content_renderer_pepper_host_factory.cc b/content/renderer/pepper/content_renderer_pepper_host_factory.cc
|
| index ec7e7ca12f1f6d8018675a6877d002d6edfeaef7..d5eb200d2658ed11789756b6348e42968433d08d 100644
|
| --- a/content/renderer/pepper/content_renderer_pepper_host_factory.cc
|
| +++ b/content/renderer/pepper/content_renderer_pepper_host_factory.cc
|
| @@ -4,8 +4,9 @@
|
|
|
| #include "content/renderer/pepper/content_renderer_pepper_host_factory.h"
|
|
|
| -#include "content/renderer/pepper/pepper_instance_state_accessor.h"
|
| +#include "base/logging.h"
|
| #include "content/renderer/pepper/pepper_file_chooser_host.h"
|
| +#include "content/renderer/pepper/renderer_ppapi_host_impl.h"
|
| #include "ppapi/host/resource_host.h"
|
| #include "ppapi/proxy/ppapi_messages.h"
|
|
|
| @@ -14,12 +15,8 @@ using ppapi::host::ResourceHost;
|
| namespace content {
|
|
|
| ContentRendererPepperHostFactory::ContentRendererPepperHostFactory(
|
| - RenderViewImpl* render_view,
|
| - const ppapi::PpapiPermissions& permissions,
|
| - PepperInstanceStateAccessor* state)
|
| - : render_view_(render_view),
|
| - permissions_(permissions),
|
| - instance_state_(state) {
|
| + RendererPpapiHostImpl* host)
|
| + : host_(host) {
|
| }
|
|
|
| ContentRendererPepperHostFactory::~ContentRendererPepperHostFactory() {
|
| @@ -30,22 +27,28 @@ scoped_ptr<ResourceHost> ContentRendererPepperHostFactory::CreateResourceHost(
|
| const ppapi::proxy::ResourceMessageCallParams& params,
|
| PP_Instance instance,
|
| const IPC::Message& message) {
|
| + DCHECK(host == host_->GetPpapiHost());
|
| +
|
| // Make sure the plugin is giving us a valid instance for this resource.
|
| - if (!instance_state_->IsValidInstance(instance))
|
| + if (!host_->IsValidInstance(instance))
|
| return scoped_ptr<ResourceHost>();
|
|
|
| // Resources for dev interfaces.
|
| // TODO(brettw) when we support any public or private interfaces, put them in
|
| // a separate switch above.
|
| - if (permissions_.HasPermission(ppapi::PERMISSION_DEV)) {
|
| + if (GetPermissions().HasPermission(ppapi::PERMISSION_DEV)) {
|
| switch (message.type()) {
|
| case PpapiHostMsg_FileChooser_Create::ID:
|
| return scoped_ptr<ResourceHost>(new PepperFileChooserHost(
|
| - host, instance, params.pp_resource(), render_view_,
|
| - instance_state_));
|
| + host_, instance, params.pp_resource()));
|
| }
|
| }
|
| return scoped_ptr<ResourceHost>();
|
| }
|
|
|
| +const ppapi::PpapiPermissions&
|
| +ContentRendererPepperHostFactory::GetPermissions() const {
|
| + return host_->GetPpapiHost()->permissions();
|
| +}
|
| +
|
| } // namespace content
|
|
|