OLD | NEW |
---|---|
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 "ppapi/cpp/var.h" | 5 #include "ppapi/cpp/var.h" |
6 | 6 |
7 #include <stdio.h> | 7 #include <stdio.h> |
8 #include <string.h> | 8 #include <string.h> |
9 | 9 |
10 #include <algorithm> | 10 #include <algorithm> |
11 | 11 |
12 #include "ppapi/c/pp_var.h" | 12 #include "ppapi/c/pp_var.h" |
13 #include "ppapi/c/ppb_var.h" | 13 #include "ppapi/c/ppb_var.h" |
14 #include "ppapi/cpp/instance.h" | 14 #include "ppapi/cpp/instance.h" |
15 #include "ppapi/cpp/logging.h" | 15 #include "ppapi/cpp/logging.h" |
16 #include "ppapi/cpp/module.h" | 16 #include "ppapi/cpp/module.h" |
17 #include "ppapi/cpp/module_impl.h" | 17 #include "ppapi/cpp/module_impl.h" |
18 | 18 |
19 // Define equivalent to snprintf on Windows. | 19 // Define equivalent to snprintf on Windows. |
20 #if defined(_MSC_VER) | 20 #if defined(_MSC_VER) |
21 # define snprintf sprintf_s | 21 # define snprintf sprintf_s |
22 #endif | 22 #endif |
23 | 23 |
24 namespace pp { | 24 namespace pp { |
25 | 25 |
26 namespace { | 26 namespace { |
27 | 27 |
28 template <> const char* interface_name<PPB_Var_1_2>() { | |
29 return PPB_VAR_INTERFACE_1_2; | |
30 } | |
28 template <> const char* interface_name<PPB_Var_1_1>() { | 31 template <> const char* interface_name<PPB_Var_1_1>() { |
29 return PPB_VAR_INTERFACE_1_1; | 32 return PPB_VAR_INTERFACE_1_1; |
30 } | 33 } |
31 template <> const char* interface_name<PPB_Var_1_0>() { | 34 template <> const char* interface_name<PPB_Var_1_0>() { |
32 return PPB_VAR_INTERFACE_1_0; | 35 return PPB_VAR_INTERFACE_1_0; |
33 } | 36 } |
34 | 37 |
35 // Technically you can call AddRef and Release on any Var, but it may involve | 38 // Technically you can call AddRef and Release on any Var, but it may involve |
36 // cross-process calls depending on the plugin. This is an optimization so we | 39 // cross-process calls depending on the plugin. This is an optimization so we |
37 // only do refcounting on the necessary objects. | 40 // only do refcounting on the necessary objects. |
38 inline bool NeedsRefcounting(const PP_Var& var) { | 41 inline bool NeedsRefcounting(const PP_Var& var) { |
39 return var.type > PP_VARTYPE_DOUBLE; | 42 return var.type > PP_VARTYPE_DOUBLE; |
40 } | 43 } |
41 | 44 |
42 // This helper function uses the latest available version of VarFromUtf8. Note | 45 // This helper function uses the latest available version of VarFromUtf8. Note |
43 // that version 1.0 of this method has a different API to later versions. | 46 // that version 1.0 of this method has a different API to later versions. |
44 PP_Var VarFromUtf8Helper(const char* utf8_str, uint32_t len) { | 47 PP_Var VarFromUtf8Helper(const char* utf8_str, uint32_t len) { |
45 if (has_interface<PPB_Var_1_1>()) { | 48 if (has_interface<PPB_Var_1_2>()) { |
49 return get_interface<PPB_Var_1_2>()->VarFromUtf8(utf8_str, len); | |
50 } else if (has_interface<PPB_Var_1_1>()) { | |
46 return get_interface<PPB_Var_1_1>()->VarFromUtf8(utf8_str, len); | 51 return get_interface<PPB_Var_1_1>()->VarFromUtf8(utf8_str, len); |
47 } else if (has_interface<PPB_Var_1_0>()) { | 52 } else if (has_interface<PPB_Var_1_0>()) { |
48 return get_interface<PPB_Var_1_0>()->VarFromUtf8(Module::Get()->pp_module(), | 53 return get_interface<PPB_Var_1_0>()->VarFromUtf8(Module::Get()->pp_module(), |
49 utf8_str, | 54 utf8_str, |
50 len); | 55 len); |
51 } else { | 56 } else { |
52 return PP_MakeNull(); | 57 return PP_MakeNull(); |
53 } | 58 } |
54 } | 59 } |
55 | 60 |
56 // This helper function uses the latest available version of AddRef. | 61 // This helper function uses the latest available version of AddRef. |
57 // Returns true on success, false if no appropriate interface was available. | 62 // Returns true on success, false if no appropriate interface was available. |
58 bool AddRefHelper(const PP_Var& var) { | 63 bool AddRefHelper(const PP_Var& var) { |
59 if (has_interface<PPB_Var_1_1>()) { | 64 if (has_interface<PPB_Var_1_2>()) { |
65 get_interface<PPB_Var_1_2>()->AddRef(var); | |
66 return true; | |
67 } else if (has_interface<PPB_Var_1_1>()) { | |
yzshen1
2014/02/10 17:00:53
nit: According to style guide, it is preferred to
dmichael (off chromium)
2014/02/10 18:31:56
I wasn't aware of that; can you point me at the pa
yzshen1
2014/02/10 19:44:14
The style guide is at: http://www.chromium.org/dev
dmichael (off chromium)
2014/02/10 20:12:51
Thanks, I was looking at the broader open source G
yzshen1
2014/02/10 22:38:41
I agree that it is not very important. :)
Please p
Matt Giuca
2014/02/11 02:41:17
I've changed the else but not the else-ifs.
| |
60 get_interface<PPB_Var_1_1>()->AddRef(var); | 68 get_interface<PPB_Var_1_1>()->AddRef(var); |
61 return true; | 69 return true; |
62 } else if (has_interface<PPB_Var_1_0>()) { | 70 } else if (has_interface<PPB_Var_1_0>()) { |
63 get_interface<PPB_Var_1_0>()->AddRef(var); | 71 get_interface<PPB_Var_1_0>()->AddRef(var); |
64 return true; | 72 return true; |
65 } else { | 73 } else { |
66 return false; | 74 return false; |
67 } | 75 } |
68 } | 76 } |
69 | 77 |
70 // This helper function uses the latest available version of Release. | 78 // This helper function uses the latest available version of Release. |
71 // Returns true on success, false if no appropriate interface was available. | 79 // Returns true on success, false if no appropriate interface was available. |
72 bool ReleaseHelper(const PP_Var& var) { | 80 bool ReleaseHelper(const PP_Var& var) { |
73 if (has_interface<PPB_Var_1_1>()) { | 81 if (has_interface<PPB_Var_1_2>()) { |
82 get_interface<PPB_Var_1_2>()->Release(var); | |
83 return true; | |
84 } else if (has_interface<PPB_Var_1_1>()) { | |
74 get_interface<PPB_Var_1_1>()->Release(var); | 85 get_interface<PPB_Var_1_1>()->Release(var); |
75 return true; | 86 return true; |
76 } else if (has_interface<PPB_Var_1_0>()) { | 87 } else if (has_interface<PPB_Var_1_0>()) { |
77 get_interface<PPB_Var_1_0>()->Release(var); | 88 get_interface<PPB_Var_1_0>()->Release(var); |
78 return true; | 89 return true; |
79 } else { | 90 } else { |
80 return false; | 91 return false; |
81 } | 92 } |
82 } | 93 } |
83 | 94 |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
121 var_ = VarFromUtf8Helper(utf8_str, len); | 132 var_ = VarFromUtf8Helper(utf8_str, len); |
122 is_managed_ = true; | 133 is_managed_ = true; |
123 } | 134 } |
124 | 135 |
125 Var::Var(const std::string& utf8_str) { | 136 Var::Var(const std::string& utf8_str) { |
126 var_ = VarFromUtf8Helper(utf8_str.c_str(), | 137 var_ = VarFromUtf8Helper(utf8_str.c_str(), |
127 static_cast<uint32_t>(utf8_str.size())); | 138 static_cast<uint32_t>(utf8_str.size())); |
128 is_managed_ = true; | 139 is_managed_ = true; |
129 } | 140 } |
130 | 141 |
142 Var::Var(const pp::Resource& resource) { | |
143 if (has_interface<PPB_Var_1_2>()) { | |
144 var_ = get_interface<PPB_Var_1_2>()->VarFromResource( | |
145 resource.pp_resource()); | |
146 } else { | |
147 PP_NOTREACHED(); | |
148 return; | |
149 } | |
150 // Set |is_managed_| to true, so |var_| will be properly released upon | |
151 // destruction. | |
152 is_managed_ = true; | |
153 } | |
154 | |
131 | 155 |
132 Var::Var(const PP_Var& var) { | 156 Var::Var(const PP_Var& var) { |
133 var_ = var; | 157 var_ = var; |
134 is_managed_ = true; | 158 is_managed_ = true; |
135 if (NeedsRefcounting(var_)) { | 159 if (NeedsRefcounting(var_)) { |
136 if (!AddRefHelper(var_)) | 160 if (!AddRefHelper(var_)) |
137 var_.type = PP_VARTYPE_NULL; | 161 var_.type = PP_VARTYPE_NULL; |
138 } | 162 } |
139 } | 163 } |
140 | 164 |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
187 case PP_VARTYPE_DOUBLE: | 211 case PP_VARTYPE_DOUBLE: |
188 return AsDouble() == other.AsDouble(); | 212 return AsDouble() == other.AsDouble(); |
189 case PP_VARTYPE_STRING: | 213 case PP_VARTYPE_STRING: |
190 if (var_.value.as_id == other.var_.value.as_id) | 214 if (var_.value.as_id == other.var_.value.as_id) |
191 return true; | 215 return true; |
192 return AsString() == other.AsString(); | 216 return AsString() == other.AsString(); |
193 case PP_VARTYPE_OBJECT: | 217 case PP_VARTYPE_OBJECT: |
194 case PP_VARTYPE_ARRAY: | 218 case PP_VARTYPE_ARRAY: |
195 case PP_VARTYPE_ARRAY_BUFFER: | 219 case PP_VARTYPE_ARRAY_BUFFER: |
196 case PP_VARTYPE_DICTIONARY: | 220 case PP_VARTYPE_DICTIONARY: |
197 default: // Objects, arrays, dictionaries. | 221 default: // Objects, arrays, dictionaries. |
yzshen1
2014/02/10 17:00:53
Please also add resource type here.
Matt Giuca
2014/02/11 02:41:17
Done. (Oh no, this should have been there even bef
| |
198 return var_.value.as_id == other.var_.value.as_id; | 222 return var_.value.as_id == other.var_.value.as_id; |
199 } | 223 } |
200 } | 224 } |
201 | 225 |
202 bool Var::AsBool() const { | 226 bool Var::AsBool() const { |
203 if (!is_bool()) { | 227 if (!is_bool()) { |
204 PP_NOTREACHED(); | 228 PP_NOTREACHED(); |
205 return false; | 229 return false; |
206 } | 230 } |
207 return PP_ToBool(var_.value.as_bool); | 231 return PP_ToBool(var_.value.as_bool); |
(...skipping 18 matching lines...) Expand all Loading... | |
226 } | 250 } |
227 | 251 |
228 std::string Var::AsString() const { | 252 std::string Var::AsString() const { |
229 if (!is_string()) { | 253 if (!is_string()) { |
230 PP_NOTREACHED(); | 254 PP_NOTREACHED(); |
231 return std::string(); | 255 return std::string(); |
232 } | 256 } |
233 | 257 |
234 uint32_t len; | 258 uint32_t len; |
235 const char* str; | 259 const char* str; |
236 if (has_interface<PPB_Var_1_1>()) | 260 if (has_interface<PPB_Var_1_2>()) |
261 str = get_interface<PPB_Var_1_2>()->VarToUtf8(var_, &len); | |
262 else if (has_interface<PPB_Var_1_1>()) | |
237 str = get_interface<PPB_Var_1_1>()->VarToUtf8(var_, &len); | 263 str = get_interface<PPB_Var_1_1>()->VarToUtf8(var_, &len); |
238 else if (has_interface<PPB_Var_1_0>()) | 264 else if (has_interface<PPB_Var_1_0>()) |
239 str = get_interface<PPB_Var_1_0>()->VarToUtf8(var_, &len); | 265 str = get_interface<PPB_Var_1_0>()->VarToUtf8(var_, &len); |
240 else | 266 else |
241 return std::string(); | 267 return std::string(); |
242 return std::string(str, len); | 268 return std::string(str, len); |
243 } | 269 } |
244 | 270 |
271 pp::Resource Var::AsResource() const { | |
272 if (!is_resource()) { | |
273 PP_NOTREACHED(); | |
274 return pp::Resource(); | |
275 } | |
276 | |
277 if (has_interface<PPB_Var_1_2>()) { | |
278 return pp::Resource(pp::PASS_REF, | |
279 get_interface<PPB_Var_1_2>()->VarToResource(var_)); | |
280 } else { | |
281 return pp::Resource(); | |
282 } | |
283 } | |
284 | |
245 std::string Var::DebugString() const { | 285 std::string Var::DebugString() const { |
246 char buf[256]; | 286 char buf[256]; |
247 if (is_undefined()) { | 287 if (is_undefined()) { |
248 snprintf(buf, sizeof(buf), "Var(UNDEFINED)"); | 288 snprintf(buf, sizeof(buf), "Var(UNDEFINED)"); |
249 } else if (is_null()) { | 289 } else if (is_null()) { |
250 snprintf(buf, sizeof(buf), "Var(NULL)"); | 290 snprintf(buf, sizeof(buf), "Var(NULL)"); |
251 } else if (is_bool()) { | 291 } else if (is_bool()) { |
252 snprintf(buf, sizeof(buf), AsBool() ? "Var(true)" : "Var(false)"); | 292 snprintf(buf, sizeof(buf), AsBool() ? "Var(true)" : "Var(false)"); |
253 } else if (is_int()) { | 293 } else if (is_int()) { |
254 snprintf(buf, sizeof(buf), "Var(%d)", static_cast<int>(AsInt())); | 294 snprintf(buf, sizeof(buf), "Var(%d)", static_cast<int>(AsInt())); |
(...skipping 10 matching lines...) Expand all Loading... | |
265 } | 305 } |
266 snprintf(buf, sizeof(buf), format, str.c_str()); | 306 snprintf(buf, sizeof(buf), format, str.c_str()); |
267 } else if (is_object()) { | 307 } else if (is_object()) { |
268 snprintf(buf, sizeof(buf), "Var(OBJECT)"); | 308 snprintf(buf, sizeof(buf), "Var(OBJECT)"); |
269 } else if (is_array()) { | 309 } else if (is_array()) { |
270 snprintf(buf, sizeof(buf), "Var(ARRAY)"); | 310 snprintf(buf, sizeof(buf), "Var(ARRAY)"); |
271 } else if (is_dictionary()) { | 311 } else if (is_dictionary()) { |
272 snprintf(buf, sizeof(buf), "Var(DICTIONARY)"); | 312 snprintf(buf, sizeof(buf), "Var(DICTIONARY)"); |
273 } else if (is_array_buffer()) { | 313 } else if (is_array_buffer()) { |
274 snprintf(buf, sizeof(buf), "Var(ARRAY_BUFFER)"); | 314 snprintf(buf, sizeof(buf), "Var(ARRAY_BUFFER)"); |
275 } else { | 315 } else { |
yzshen1
2014/02/10 17:00:53
please also add resource here.
Matt Giuca
2014/02/11 02:41:17
Done.
| |
276 buf[0] = '\0'; | 316 buf[0] = '\0'; |
277 } | 317 } |
278 return buf; | 318 return buf; |
279 } | 319 } |
280 | 320 |
281 } // namespace pp | 321 } // namespace pp |
OLD | NEW |