// Copyright (c) 2010 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_RENDERER_PEPPER_PLUGIN_OBJECT_H_
#define CONTENT_RENDERER_PEPPER_PLUGIN_OBJECT_H_
#include <string>
#include "base/basictypes.h"
struct PP_Var;
struct PPP_Class_Deprecated;
typedef struct NPObject NPObject;
typedef struct _NPVariant NPVariant;
namespace content {
class PepperPluginInstanceImpl;
// A PluginObject is a JS-accessible object implemented by the plugin.
//
// In contrast, a var of type PP_VARTYPE_OBJECT is a reference to a JS object,
// which might be implemented by the plugin (here) or by the JS engine.
class PluginObject {
public:
virtual ~PluginObject();
// Allocates a new PluginObject and returns it as a PP_Var with a
// refcount of 1.
static PP_Var Create(PepperPluginInstanceImpl* instance,
const PPP_Class_Deprecated* ppp_class,
void* ppp_class_data);
PepperPluginInstanceImpl* instance() const { return instance_; }
const PPP_Class_Deprecated* ppp_class() { return ppp_class_; }
void* ppp_class_data() {
return ppp_class_data_;
};
NPObject* GetNPObject() const;
// Returns true if the given var is an object implemented by the same plugin
// that owns the var object, and that the class matches. If it matches,
// returns true and places the class data into |*ppp_class_data| (which can
// optionally be NULL if no class data is desired).
static bool IsInstanceOf(NPObject* np_object,
const PPP_Class_Deprecated* ppp_class,
void** ppp_class_data);
// Converts the given NPObject to the corresponding ObjectVar.
//
// The given NPObject must be one corresponding to a PluginObject or this
// will crash. If the object is a PluginObject but the plugin has gone
// away (the object could still be alive because of a reference from JS),
// then the return value will be NULL.
static PluginObject* FromNPObject(NPObject* object);
// Allocates a plugin wrapper object and returns it as an NPObject. This is
// used internally only.
static NPObject* AllocateObjectWrapper();
private:
struct NPObjectWrapper;
// This object must be created using the CreateObject function of the which
// will set up the correct NPObject.
//
// The NPObjectWrapper (an NPObject) should already have the reference
// incremented on it, and this class will take ownership of that reference.
PluginObject(PepperPluginInstanceImpl* instance,
NPObjectWrapper* object_wrapper,
const PPP_Class_Deprecated* ppp_class,
void* ppp_class_data);
PepperPluginInstanceImpl* instance_;
// Holds a pointer to the NPObject wrapper backing the var. This class
// derives from NPObject and we hold a reference to it, so it must be
// refcounted. When the type is not an object, this value will be NULL.
//
// We don't actually own this pointer, it's the NPObject that actually
// owns us.
NPObjectWrapper* object_wrapper_;
const PPP_Class_Deprecated* ppp_class_;
void* ppp_class_data_;
DISALLOW_COPY_AND_ASSIGN(PluginObject);
};
} // namespace content
#endif // CONTENT_RENDERER_PEPPER_PLUGIN_OBJECT_H_