Index: ppapi/proxy/plugin_var_serialization_rules.h |
diff --git a/ppapi/proxy/plugin_var_serialization_rules.h b/ppapi/proxy/plugin_var_serialization_rules.h |
index 174c4bb473971902a6b67ce13c7dc0838fb3ebf4..87b2f3168194f60f31a6ae5dab1a46e489fbfd48 100644 |
--- a/ppapi/proxy/plugin_var_serialization_rules.h |
+++ b/ppapi/proxy/plugin_var_serialization_rules.h |
@@ -6,34 +6,44 @@ |
#define PPAPI_PROXY_PLUGIN_VAR_SERIALIZATION_RULES_H_ |
#include "base/basictypes.h" |
+#include "base/memory/weak_ptr.h" |
#include "ppapi/proxy/var_serialization_rules.h" |
namespace ppapi { |
namespace proxy { |
+class PluginDispatcher; |
class PluginVarTracker; |
-// Implementation of the VarSerialization interface for the plugin. |
+// Implementation of the VarSerializationRules interface for the plugin. |
class PluginVarSerializationRules : public VarSerializationRules { |
public: |
// This class will use the given non-owning pointer to the var tracker to |
// handle object refcounting and string conversion. |
- PluginVarSerializationRules(); |
+ explicit PluginVarSerializationRules( |
+ const base::WeakPtr<PluginDispatcher>& dispatcher); |
~PluginVarSerializationRules(); |
// VarSerialization implementation. |
virtual PP_Var SendCallerOwned(const PP_Var& var); |
- virtual PP_Var BeginReceiveCallerOwned(const PP_Var& var, |
- Dispatcher* dispatcher); |
+ virtual PP_Var BeginReceiveCallerOwned(const PP_Var& var); |
virtual void EndReceiveCallerOwned(const PP_Var& var); |
- virtual PP_Var ReceivePassRef(const PP_Var& var, Dispatcher* dispatcher); |
+ virtual PP_Var ReceivePassRef(const PP_Var& var); |
virtual PP_Var BeginSendPassRef(const PP_Var& var); |
- virtual void EndSendPassRef(const PP_Var& var, Dispatcher* dispatcher); |
+ virtual void EndSendPassRef(const PP_Var& var); |
virtual void ReleaseObjectRef(const PP_Var& var); |
private: |
PluginVarTracker* var_tracker_; |
+ // In most cases, |dispatcher_| won't be NULL. |
brettw
2012/03/09 21:57:22
Can you make it clear here the you should check th
yzshen1
2012/03/09 22:05:48
Done.
|
+ // One scenario that it becomes NULL: A SerializedVar holds a ref to this |
+ // object, and a sync message is issued. While waiting for the reply to the |
+ // sync message, some incoming message causes the dispatcher to be destroyed. |
+ // If that happens, we may leak references to object vars. Considering that |
+ // scripting has been deprecated, this may not be a big issue. |
+ base::WeakPtr<PluginDispatcher> dispatcher_; |
+ |
DISALLOW_COPY_AND_ASSIGN(PluginVarSerializationRules); |
}; |