OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "ppapi/proxy/plugin_var_serialization_rules.h" | 5 #include "ppapi/proxy/plugin_var_serialization_rules.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "ppapi/proxy/plugin_dispatcher.h" | 8 #include "ppapi/proxy/plugin_dispatcher.h" |
9 #include "ppapi/proxy/plugin_resource_tracker.h" | 9 #include "ppapi/proxy/plugin_resource_tracker.h" |
10 #include "ppapi/proxy/plugin_var_tracker.h" | 10 #include "ppapi/proxy/plugin_var_tracker.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 } | 21 } |
22 | 22 |
23 PP_Var PluginVarSerializationRules::SendCallerOwned(const PP_Var& var, | 23 PP_Var PluginVarSerializationRules::SendCallerOwned(const PP_Var& var, |
24 std::string* str_val) { | 24 std::string* str_val) { |
25 // Objects need special translations to get the IDs valid in the host. | 25 // Objects need special translations to get the IDs valid in the host. |
26 if (var.type == PP_VARTYPE_OBJECT) | 26 if (var.type == PP_VARTYPE_OBJECT) |
27 return var_tracker_->GetHostObject(var); | 27 return var_tracker_->GetHostObject(var); |
28 | 28 |
29 // Retrieve the string to use for IPC. | 29 // Retrieve the string to use for IPC. |
30 if (var.type == PP_VARTYPE_STRING) { | 30 if (var.type == PP_VARTYPE_STRING) { |
31 scoped_refptr<StringVar> string_var(StringVar::FromPPVar(var)); | 31 StringVar* string_var = StringVar::FromPPVar(var); |
32 if (string_var.get()) | 32 if (string_var) |
33 *str_val = string_var->value(); | 33 *str_val = string_var->value(); |
34 else | 34 else |
35 NOTREACHED() << "Trying to send unknown string over IPC."; | 35 NOTREACHED() << "Trying to send unknown string over IPC."; |
36 } | 36 } |
37 return var; | 37 return var; |
38 } | 38 } |
39 | 39 |
40 PP_Var PluginVarSerializationRules::BeginReceiveCallerOwned( | 40 PP_Var PluginVarSerializationRules::BeginReceiveCallerOwned( |
41 const PP_Var& var, | 41 const PP_Var& var, |
42 const std::string* str_val, | 42 const std::string* str_val, |
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
109 // entire ref count in the plugin. When the plugin refcount goes to 0, it | 109 // entire ref count in the plugin. When the plugin refcount goes to 0, it |
110 // will call the browser to deref the object. This is why in example 2 | 110 // will call the browser to deref the object. This is why in example 2 |
111 // transferring the object ref to the browser involves no net change in the | 111 // transferring the object ref to the browser involves no net change in the |
112 // browser's refcount. | 112 // browser's refcount. |
113 | 113 |
114 // Objects need special translations to get the IDs valid in the host. | 114 // Objects need special translations to get the IDs valid in the host. |
115 if (var.type == PP_VARTYPE_OBJECT) | 115 if (var.type == PP_VARTYPE_OBJECT) |
116 return var_tracker_->GetHostObject(var); | 116 return var_tracker_->GetHostObject(var); |
117 | 117 |
118 if (var.type == PP_VARTYPE_STRING) { | 118 if (var.type == PP_VARTYPE_STRING) { |
119 scoped_refptr<StringVar> string_var(StringVar::FromPPVar(var)); | 119 StringVar* string_var = StringVar::FromPPVar(var); |
120 if (string_var.get()) | 120 if (string_var) |
121 *str_val = string_var->value(); | 121 *str_val = string_var->value(); |
122 else | 122 else |
123 NOTREACHED() << "Trying to send unknown string over IPC."; | 123 NOTREACHED() << "Trying to send unknown string over IPC."; |
124 } | 124 } |
125 return var; | 125 return var; |
126 } | 126 } |
127 | 127 |
128 void PluginVarSerializationRules::EndSendPassRef(const PP_Var& var, | 128 void PluginVarSerializationRules::EndSendPassRef(const PP_Var& var, |
129 Dispatcher* dispatcher) { | 129 Dispatcher* dispatcher) { |
130 // See BeginSendPassRef for an example of why we release our ref here. | 130 // See BeginSendPassRef for an example of why we release our ref here. |
131 // The var we have in our inner class has been converted to a host object | 131 // The var we have in our inner class has been converted to a host object |
132 // by BeginSendPassRef. This means it's not a normal var valid in the plugin, | 132 // by BeginSendPassRef. This means it's not a normal var valid in the plugin, |
133 // so we need to use the special ReleaseHostObject. | 133 // so we need to use the special ReleaseHostObject. |
134 if (var.type == PP_VARTYPE_OBJECT) { | 134 if (var.type == PP_VARTYPE_OBJECT) { |
135 var_tracker_->ReleaseHostObject( | 135 var_tracker_->ReleaseHostObject( |
136 static_cast<PluginDispatcher*>(dispatcher), var); | 136 static_cast<PluginDispatcher*>(dispatcher), var); |
137 } | 137 } |
138 } | 138 } |
139 | 139 |
140 void PluginVarSerializationRules::ReleaseObjectRef(const PP_Var& var) { | 140 void PluginVarSerializationRules::ReleaseObjectRef(const PP_Var& var) { |
141 var_tracker_->ReleaseVar(var); | 141 var_tracker_->ReleaseVar(var); |
142 } | 142 } |
143 | 143 |
144 } // namespace proxy | 144 } // namespace proxy |
145 } // namespace ppapi | 145 } // namespace ppapi |
OLD | NEW |