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 "gpu/tools/compositor_model_bench/render_tree.h" | 5 #include "gpu/tools/compositor_model_bench/render_tree.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 #include <sstream> | 8 #include <sstream> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
12 #include "base/files/file_util.h" | 12 #include "base/files/file_util.h" |
13 #include "base/json/json_reader.h" | 13 #include "base/json/json_reader.h" |
14 #include "base/json/json_writer.h" | 14 #include "base/json/json_writer.h" |
15 #include "base/logging.h" | 15 #include "base/logging.h" |
16 #include "base/values.h" | 16 #include "base/values.h" |
17 #include "gpu/tools/compositor_model_bench/shaders.h" | 17 #include "gpu/tools/compositor_model_bench/shaders.h" |
18 | 18 |
19 using base::JSONReader; | 19 using base::JSONReader; |
20 using base::JSONWriter; | 20 using base::JSONWriter; |
21 using base::ReadFileToString; | 21 using base::ReadFileToString; |
22 using std::string; | 22 using base::Value; |
23 using std::vector; | |
24 | 23 |
25 GLenum TextureFormatFromString(const std::string& format) { | 24 GLenum TextureFormatFromString(const std::string& format) { |
26 if (format == "RGBA") | 25 if (format == "RGBA") |
27 return GL_RGBA; | 26 return GL_RGBA; |
28 if (format == "RGB") | 27 if (format == "RGB") |
29 return GL_RGB; | 28 return GL_RGB; |
30 if (format == "LUMINANCE") | 29 if (format == "LUMINANCE") |
31 return GL_LUMINANCE; | 30 return GL_LUMINANCE; |
32 return GL_INVALID_ENUM; | 31 return GL_INVALID_ENUM; |
33 } | 32 } |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
109 } | 108 } |
110 | 109 |
111 void RenderNodeVisitor::EndVisitContentLayerNode(ContentLayerNode* v) { | 110 void RenderNodeVisitor::EndVisitContentLayerNode(ContentLayerNode* v) { |
112 this->EndVisitRenderNode(v); | 111 this->EndVisitRenderNode(v); |
113 } | 112 } |
114 | 113 |
115 void RenderNodeVisitor::EndVisitCCNode(CCNode* v) { | 114 void RenderNodeVisitor::EndVisitCCNode(CCNode* v) { |
116 this->EndVisitRenderNode(v); | 115 this->EndVisitRenderNode(v); |
117 } | 116 } |
118 | 117 |
119 RenderNode* InterpretNode(base::DictionaryValue* node); | 118 std::unique_ptr<RenderNode> InterpretNode(const base::DictionaryValue& node); |
120 | 119 |
121 std::string ValueTypeAsString(base::Value::Type type) { | 120 std::string ValueTypeAsString(Value::Type type) { |
122 switch (type) { | 121 switch (type) { |
123 case base::Value::TYPE_NULL: | 122 case Value::TYPE_NULL: |
124 return "NULL"; | 123 return "NULL"; |
125 case base::Value::TYPE_BOOLEAN: | 124 case Value::TYPE_BOOLEAN: |
126 return "BOOLEAN"; | 125 return "BOOLEAN"; |
127 case base::Value::TYPE_INTEGER: | 126 case Value::TYPE_INTEGER: |
128 return "INTEGER"; | 127 return "INTEGER"; |
129 case base::Value::TYPE_DOUBLE: | 128 case Value::TYPE_DOUBLE: |
130 return "DOUBLE"; | 129 return "DOUBLE"; |
131 case base::Value::TYPE_STRING: | 130 case Value::TYPE_STRING: |
132 return "STRING"; | 131 return "STRING"; |
133 case base::Value::TYPE_BINARY: | 132 case Value::TYPE_BINARY: |
134 return "BINARY"; | 133 return "BINARY"; |
135 case base::Value::TYPE_DICTIONARY: | 134 case Value::TYPE_DICTIONARY: |
136 return "DICTIONARY"; | 135 return "DICTIONARY"; |
137 case base::Value::TYPE_LIST: | 136 case Value::TYPE_LIST: |
138 return "LIST"; | 137 return "LIST"; |
139 default: | 138 default: |
140 return "(UNKNOWN TYPE)"; | 139 return "(UNKNOWN TYPE)"; |
141 } | 140 } |
142 } | 141 } |
143 | 142 |
144 // Makes sure that the key exists and has the type we expect. | 143 // Makes sure that the key exists and has the type we expect. |
145 bool VerifyDictionaryEntry(base::DictionaryValue* node, | 144 bool VerifyDictionaryEntry(const base::DictionaryValue& node, |
146 const std::string& key, | 145 const std::string& key, |
147 base::Value::Type type) { | 146 Value::Type type) { |
148 if (!node->HasKey(key)) { | 147 if (!node.HasKey(key)) { |
149 LOG(ERROR) << "Missing value for key: " << key; | 148 LOG(ERROR) << "Missing value for key: " << key; |
150 return false; | 149 return false; |
151 } | 150 } |
152 | 151 |
153 base::Value* child; | 152 const Value* child; |
154 node->Get(key, &child); | 153 node.Get(key, &child); |
155 if (!child->IsType(type)) { | 154 if (!child->IsType(type)) { |
156 LOG(ERROR) << key << " did not have the expected type " | 155 LOG(ERROR) << key << " did not have the expected type " |
157 "(expected " << ValueTypeAsString(type) << ")"; | 156 "(expected " << ValueTypeAsString(type) << ")"; |
158 return false; | 157 return false; |
159 } | 158 } |
160 | 159 |
161 return true; | 160 return true; |
162 } | 161 } |
163 | 162 |
164 // Makes sure that the list entry has the type we expect. | 163 // Makes sure that the list entry has the type we expect. |
165 bool VerifyListEntry(base::ListValue* l, | 164 bool VerifyListEntry(const base::ListValue& l, |
166 int idx, | 165 int idx, |
167 base::Value::Type type, | 166 Value::Type type, |
168 const char* listName = 0) { | 167 const char* listName = nullptr) { |
169 // Assume the idx is valid (since we'll be able to generate a better | 168 // Assume the idx is valid (since we'll be able to generate a better |
170 // error message for this elsewhere.) | 169 // error message for this elsewhere.) |
171 base::Value* el; | 170 const Value* el; |
172 l->Get(idx, &el); | 171 l.Get(idx, &el); |
173 if (!el->IsType(type)) { | 172 if (!el->IsType(type)) { |
174 LOG(ERROR) << (listName ? listName : "List") << "element " << idx << | 173 LOG(ERROR) << (listName ? listName : "List") << "element " << idx |
175 " did not have the expected type (expected " << | 174 << " did not have the expected type (expected " |
176 ValueTypeAsString(type) << ")\n"; | 175 << ValueTypeAsString(type) << ")\n"; |
177 return false; | 176 return false; |
178 } | 177 } |
179 | 178 |
180 return true; | 179 return true; |
181 } | 180 } |
182 | 181 |
183 bool InterpretCommonContents(base::DictionaryValue* node, RenderNode* c) { | 182 bool InterpretCommonContents(const base::DictionaryValue& node, RenderNode* c) { |
184 if (!VerifyDictionaryEntry(node, "layerID", base::Value::TYPE_INTEGER) || | 183 if (!VerifyDictionaryEntry(node, "layerID", Value::TYPE_INTEGER) || |
185 !VerifyDictionaryEntry(node, "width", base::Value::TYPE_INTEGER) || | 184 !VerifyDictionaryEntry(node, "width", Value::TYPE_INTEGER) || |
186 !VerifyDictionaryEntry(node, "height", base::Value::TYPE_INTEGER) || | 185 !VerifyDictionaryEntry(node, "height", Value::TYPE_INTEGER) || |
187 !VerifyDictionaryEntry(node, "drawsContent", base::Value::TYPE_BOOLEAN) || | 186 !VerifyDictionaryEntry(node, "drawsContent", Value::TYPE_BOOLEAN) || |
188 !VerifyDictionaryEntry(node, "targetSurfaceID", | 187 !VerifyDictionaryEntry(node, "targetSurfaceID", Value::TYPE_INTEGER) || |
189 base::Value::TYPE_INTEGER) || | 188 !VerifyDictionaryEntry(node, "transform", Value::TYPE_LIST)) { |
190 !VerifyDictionaryEntry(node, "transform", base::Value::TYPE_LIST) | |
191 ) { | |
192 return false; | 189 return false; |
193 } | 190 } |
194 | 191 |
195 int layerID; | 192 int layerID; |
196 node->GetInteger("layerID", &layerID); | 193 node.GetInteger("layerID", &layerID); |
197 c->set_layerID(layerID); | 194 c->set_layerID(layerID); |
198 int width; | 195 int width; |
199 node->GetInteger("width", &width); | 196 node.GetInteger("width", &width); |
200 c->set_width(width); | 197 c->set_width(width); |
201 int height; | 198 int height; |
202 node->GetInteger("height", &height); | 199 node.GetInteger("height", &height); |
203 c->set_height(height); | 200 c->set_height(height); |
204 bool drawsContent; | 201 bool drawsContent; |
205 node->GetBoolean("drawsContent", &drawsContent); | 202 node.GetBoolean("drawsContent", &drawsContent); |
206 c->set_drawsContent(drawsContent); | 203 c->set_drawsContent(drawsContent); |
207 int targetSurface; | 204 int targetSurface; |
208 node->GetInteger("targetSurfaceID", &targetSurface); | 205 node.GetInteger("targetSurfaceID", &targetSurface); |
209 c->set_targetSurface(targetSurface); | 206 c->set_targetSurface(targetSurface); |
210 | 207 |
211 base::ListValue* transform; | 208 const base::ListValue* transform; |
212 node->GetList("transform", &transform); | 209 node.GetList("transform", &transform); |
213 if (transform->GetSize() != 16) { | 210 if (transform->GetSize() != 16) { |
214 LOG(ERROR) << "4x4 transform matrix did not have 16 elements"; | 211 LOG(ERROR) << "4x4 transform matrix did not have 16 elements"; |
215 return false; | 212 return false; |
216 } | 213 } |
217 float transform_mat[16]; | 214 float transform_mat[16]; |
218 for (int i = 0; i < 16; ++i) { | 215 for (int i = 0; i < 16; ++i) { |
219 if (!VerifyListEntry(transform, i, base::Value::TYPE_DOUBLE, "Transform")) | 216 if (!VerifyListEntry(*transform, i, Value::TYPE_DOUBLE, "Transform")) |
220 return false; | 217 return false; |
221 double el; | 218 double el; |
222 transform->GetDouble(i, &el); | 219 transform->GetDouble(i, &el); |
223 transform_mat[i] = el; | 220 transform_mat[i] = el; |
224 } | 221 } |
225 c->set_transform(transform_mat); | 222 c->set_transform(transform_mat); |
226 | 223 |
227 if (node->HasKey("tiles")) { | 224 if (!node.HasKey("tiles")) |
228 if (!VerifyDictionaryEntry(node, "tiles", base::Value::TYPE_DICTIONARY)) | 225 return true; |
| 226 |
| 227 if (!VerifyDictionaryEntry(node, "tiles", Value::TYPE_DICTIONARY)) |
| 228 return false; |
| 229 const base::DictionaryValue* tiles_dict; |
| 230 node.GetDictionary("tiles", &tiles_dict); |
| 231 if (!VerifyDictionaryEntry(*tiles_dict, "dim", Value::TYPE_LIST)) |
| 232 return false; |
| 233 const base::ListValue* dim; |
| 234 tiles_dict->GetList("dim", &dim); |
| 235 if (!VerifyListEntry(*dim, 0, Value::TYPE_INTEGER, "Tile dimension") || |
| 236 !VerifyListEntry(*dim, 1, Value::TYPE_INTEGER, "Tile dimension")) { |
| 237 return false; |
| 238 } |
| 239 int tile_width; |
| 240 dim->GetInteger(0, &tile_width); |
| 241 c->set_tile_width(tile_width); |
| 242 int tile_height; |
| 243 dim->GetInteger(1, &tile_height); |
| 244 c->set_tile_height(tile_height); |
| 245 |
| 246 if (!VerifyDictionaryEntry(*tiles_dict, "info", Value::TYPE_LIST)) |
| 247 return false; |
| 248 const base::ListValue* tiles; |
| 249 tiles_dict->GetList("info", &tiles); |
| 250 for (unsigned int i = 0; i < tiles->GetSize(); ++i) { |
| 251 if (!VerifyListEntry(*tiles, i, Value::TYPE_DICTIONARY, "Tile info")) |
229 return false; | 252 return false; |
230 base::DictionaryValue* tiles_dict; | 253 const base::DictionaryValue* tdict; |
231 node->GetDictionary("tiles", &tiles_dict); | 254 tiles->GetDictionary(i, &tdict); |
232 if (!VerifyDictionaryEntry(tiles_dict, "dim", base::Value::TYPE_LIST)) | 255 |
233 return false; | 256 if (!VerifyDictionaryEntry(*tdict, "x", Value::TYPE_INTEGER) || |
234 base::ListValue* dim; | 257 !VerifyDictionaryEntry(*tdict, "y", Value::TYPE_INTEGER)) { |
235 tiles_dict->GetList("dim", &dim); | |
236 if (!VerifyListEntry(dim, 0, base::Value::TYPE_INTEGER, "Tile dimension") || | |
237 !VerifyListEntry(dim, 1, base::Value::TYPE_INTEGER, "Tile dimension")) { | |
238 return false; | 258 return false; |
239 } | 259 } |
240 int tile_width; | 260 Tile t; |
241 dim->GetInteger(0, &tile_width); | 261 tdict->GetInteger("x", &t.x); |
242 c->set_tile_width(tile_width); | 262 tdict->GetInteger("y", &t.y); |
243 int tile_height; | 263 if (tdict->HasKey("texID")) { |
244 dim->GetInteger(1, &tile_height); | 264 if (!VerifyDictionaryEntry(*tdict, "texID", Value::TYPE_INTEGER)) |
245 c->set_tile_height(tile_height); | |
246 | |
247 if (!VerifyDictionaryEntry(tiles_dict, "info", base::Value::TYPE_LIST)) | |
248 return false; | |
249 base::ListValue* tiles; | |
250 tiles_dict->GetList("info", &tiles); | |
251 for (unsigned int i = 0; i < tiles->GetSize(); ++i) { | |
252 if (!VerifyListEntry(tiles, i, base::Value::TYPE_DICTIONARY, "Tile info")) | |
253 return false; | 265 return false; |
254 base::DictionaryValue* tdict; | 266 tdict->GetInteger("texID", &t.texID); |
255 tiles->GetDictionary(i, &tdict); | 267 } else { |
256 | 268 t.texID = -1; |
257 if (!VerifyDictionaryEntry(tdict, "x", base::Value::TYPE_INTEGER) || | |
258 !VerifyDictionaryEntry(tdict, "y", base::Value::TYPE_INTEGER)) { | |
259 return false; | |
260 } | |
261 Tile t; | |
262 tdict->GetInteger("x", &t.x); | |
263 tdict->GetInteger("y", &t.y); | |
264 if (tdict->HasKey("texID")) { | |
265 if (!VerifyDictionaryEntry(tdict, "texID", base::Value::TYPE_INTEGER)) | |
266 return false; | |
267 tdict->GetInteger("texID", &t.texID); | |
268 } else { | |
269 t.texID = -1; | |
270 } | |
271 c->add_tile(t); | |
272 } | 269 } |
| 270 c->add_tile(t); |
273 } | 271 } |
274 return true; | 272 return true; |
275 } | 273 } |
276 | 274 |
277 bool InterpretCCData(base::DictionaryValue* node, CCNode* c) { | 275 bool InterpretCCData(const base::DictionaryValue& node, CCNode* c) { |
278 if (!VerifyDictionaryEntry(node, "vertex_shader", base::Value::TYPE_STRING) || | 276 if (!VerifyDictionaryEntry(node, "vertex_shader", Value::TYPE_STRING) || |
279 !VerifyDictionaryEntry(node, "fragment_shader", | 277 !VerifyDictionaryEntry(node, "fragment_shader", Value::TYPE_STRING) || |
280 base::Value::TYPE_STRING) || | 278 !VerifyDictionaryEntry(node, "textures", Value::TYPE_LIST)) { |
281 !VerifyDictionaryEntry(node, "textures", base::Value::TYPE_LIST)) { | |
282 return false; | 279 return false; |
283 } | 280 } |
284 string vertex_shader_name, fragment_shader_name; | 281 std::string vertex_shader_name, fragment_shader_name; |
285 node->GetString("vertex_shader", &vertex_shader_name); | 282 node.GetString("vertex_shader", &vertex_shader_name); |
286 node->GetString("fragment_shader", &fragment_shader_name); | 283 node.GetString("fragment_shader", &fragment_shader_name); |
287 | 284 |
288 c->set_vertex_shader(ShaderIDFromString(vertex_shader_name)); | 285 c->set_vertex_shader(ShaderIDFromString(vertex_shader_name)); |
289 c->set_fragment_shader(ShaderIDFromString(fragment_shader_name)); | 286 c->set_fragment_shader(ShaderIDFromString(fragment_shader_name)); |
290 base::ListValue* textures; | 287 const base::ListValue* textures; |
291 node->GetList("textures", &textures); | 288 node.GetList("textures", &textures); |
292 for (unsigned int i = 0; i < textures->GetSize(); ++i) { | 289 for (unsigned int i = 0; i < textures->GetSize(); ++i) { |
293 if (!VerifyListEntry(textures, i, base::Value::TYPE_DICTIONARY, "Tex list")) | 290 if (!VerifyListEntry(*textures, i, Value::TYPE_DICTIONARY, "Tex list")) |
294 return false; | 291 return false; |
295 base::DictionaryValue* tex; | 292 const base::DictionaryValue* tex; |
296 textures->GetDictionary(i, &tex); | 293 textures->GetDictionary(i, &tex); |
297 | 294 |
298 if (!VerifyDictionaryEntry(tex, "texID", base::Value::TYPE_INTEGER) || | 295 if (!VerifyDictionaryEntry(*tex, "texID", Value::TYPE_INTEGER) || |
299 !VerifyDictionaryEntry(tex, "height", base::Value::TYPE_INTEGER) || | 296 !VerifyDictionaryEntry(*tex, "height", Value::TYPE_INTEGER) || |
300 !VerifyDictionaryEntry(tex, "width", base::Value::TYPE_INTEGER) || | 297 !VerifyDictionaryEntry(*tex, "width", Value::TYPE_INTEGER) || |
301 !VerifyDictionaryEntry(tex, "format", base::Value::TYPE_STRING)) { | 298 !VerifyDictionaryEntry(*tex, "format", Value::TYPE_STRING)) { |
302 return false; | 299 return false; |
303 } | 300 } |
304 Texture t; | 301 Texture t; |
305 tex->GetInteger("texID", &t.texID); | 302 tex->GetInteger("texID", &t.texID); |
306 tex->GetInteger("height", &t.height); | 303 tex->GetInteger("height", &t.height); |
307 tex->GetInteger("width", &t.width); | 304 tex->GetInteger("width", &t.width); |
308 | 305 |
309 string formatName; | 306 std::string formatName; |
310 tex->GetString("format", &formatName); | 307 tex->GetString("format", &formatName); |
311 t.format = TextureFormatFromString(formatName); | 308 t.format = TextureFormatFromString(formatName); |
312 if (t.format == GL_INVALID_ENUM) { | 309 if (t.format == GL_INVALID_ENUM) { |
313 LOG(ERROR) << "Unrecognized texture format in layer " << c->layerID() << | 310 LOG(ERROR) << "Unrecognized texture format in layer " << c->layerID() |
314 " (format: " << formatName << ")\n" | 311 << " (format: " << formatName << ")\n" |
315 "The layer had " << textures->GetSize() << " children."; | 312 "The layer had " |
| 313 << textures->GetSize() << " children."; |
316 return false; | 314 return false; |
317 } | 315 } |
318 | 316 |
319 c->add_texture(t); | 317 c->add_texture(t); |
320 } | 318 } |
321 | 319 |
322 if (c->vertex_shader() == SHADER_UNRECOGNIZED) { | 320 if (c->vertex_shader() == SHADER_UNRECOGNIZED) { |
323 LOG(ERROR) << "Unrecognized vertex shader name, layer " << c->layerID() << | 321 LOG(ERROR) << "Unrecognized vertex shader name, layer " << c->layerID() |
324 " (shader: " << vertex_shader_name << ")"; | 322 << " (shader: " << vertex_shader_name << ")"; |
325 return false; | 323 return false; |
326 } | 324 } |
327 | 325 |
328 if (c->fragment_shader() == SHADER_UNRECOGNIZED) { | 326 if (c->fragment_shader() == SHADER_UNRECOGNIZED) { |
329 LOG(ERROR) << "Unrecognized fragment shader name, layer " << c->layerID() << | 327 LOG(ERROR) << "Unrecognized fragment shader name, layer " << c->layerID() |
330 " (shader: " << fragment_shader_name << ")"; | 328 << " (shader: " << fragment_shader_name << ")"; |
331 return false; | 329 return false; |
332 } | 330 } |
333 | 331 |
334 return true; | 332 return true; |
335 } | 333 } |
336 | 334 |
337 RenderNode* InterpretContentLayer(base::DictionaryValue* node) { | 335 std::unique_ptr<RenderNode> InterpretContentLayer( |
338 ContentLayerNode* n = new ContentLayerNode; | 336 const base::DictionaryValue& node) { |
339 if (!InterpretCommonContents(node, n)) | 337 auto n = base::MakeUnique<ContentLayerNode>(); |
340 return NULL; | 338 if (!InterpretCommonContents(node, n.get())) |
| 339 return nullptr; |
341 | 340 |
342 if (!VerifyDictionaryEntry(node, "type", base::Value::TYPE_STRING) || | 341 if (!VerifyDictionaryEntry(node, "type", Value::TYPE_STRING) || |
343 !VerifyDictionaryEntry(node, "skipsDraw", base::Value::TYPE_BOOLEAN) || | 342 !VerifyDictionaryEntry(node, "skipsDraw", Value::TYPE_BOOLEAN) || |
344 !VerifyDictionaryEntry(node, "children", base::Value::TYPE_LIST)) { | 343 !VerifyDictionaryEntry(node, "children", Value::TYPE_LIST)) { |
345 return NULL; | 344 return nullptr; |
346 } | 345 } |
347 | 346 |
348 string type; | 347 std::string type; |
349 node->GetString("type", &type); | 348 node.GetString("type", &type); |
350 DCHECK_EQ(type, "ContentLayer"); | 349 DCHECK_EQ(type, "ContentLayer"); |
351 bool skipsDraw; | 350 bool skipsDraw; |
352 node->GetBoolean("skipsDraw", &skipsDraw); | 351 node.GetBoolean("skipsDraw", &skipsDraw); |
353 n->set_skipsDraw(skipsDraw); | 352 n->set_skipsDraw(skipsDraw); |
354 | 353 |
355 base::ListValue* children; | 354 const base::ListValue* children; |
356 node->GetList("children", &children); | 355 node.GetList("children", &children); |
357 for (unsigned int i = 0; i < children->GetSize(); ++i) { | 356 for (unsigned int i = 0; i < children->GetSize(); ++i) { |
358 base::DictionaryValue* childNode; | 357 const base::DictionaryValue* childNode; |
359 children->GetDictionary(i, &childNode); | 358 if (!children->GetDictionary(i, &childNode)) |
360 RenderNode* child = InterpretNode(childNode); | 359 continue; |
| 360 std::unique_ptr<RenderNode> child = InterpretNode(*childNode); |
361 if (child) | 361 if (child) |
362 n->add_child(child); | 362 n->add_child(child.release()); |
363 } | 363 } |
364 | 364 |
365 return n; | 365 return n; |
366 } | 366 } |
367 | 367 |
368 RenderNode* InterpretCanvasLayer(base::DictionaryValue* node) { | 368 std::unique_ptr<RenderNode> InterpretCanvasLayer( |
369 CCNode* n = new CCNode; | 369 const base::DictionaryValue& node) { |
370 if (!InterpretCommonContents(node, n)) | 370 auto n = base::MakeUnique<CCNode>(); |
371 return NULL; | 371 if (!InterpretCommonContents(node, n.get())) |
| 372 return nullptr; |
372 | 373 |
373 if (!VerifyDictionaryEntry(node, "type", base::Value::TYPE_STRING)) { | 374 if (!VerifyDictionaryEntry(node, "type", Value::TYPE_STRING)) |
374 return NULL; | 375 return nullptr; |
375 } | |
376 | 376 |
377 string type; | 377 std::string type; |
378 node->GetString("type", &type); | 378 node.GetString("type", &type); |
379 assert(type == "CanvasLayer"); | 379 assert(type == "CanvasLayer"); |
380 | 380 |
381 if (!InterpretCCData(node, n)) | 381 if (!InterpretCCData(node, n.get())) |
382 return NULL; | 382 return nullptr; |
383 | 383 |
384 return n; | 384 return n; |
385 } | 385 } |
386 | 386 |
387 RenderNode* InterpretVideoLayer(base::DictionaryValue* node) { | 387 std::unique_ptr<RenderNode> InterpretVideoLayer( |
388 CCNode* n = new CCNode; | 388 const base::DictionaryValue& node) { |
389 if (!InterpretCommonContents(node, n)) | 389 auto n = base::MakeUnique<CCNode>(); |
390 return NULL; | 390 if (!InterpretCommonContents(node, n.get())) |
| 391 return nullptr; |
391 | 392 |
392 if (!VerifyDictionaryEntry(node, "type", base::Value::TYPE_STRING)) { | 393 if (!VerifyDictionaryEntry(node, "type", Value::TYPE_STRING)) |
393 return NULL; | 394 return nullptr; |
394 } | |
395 | 395 |
396 string type; | 396 std::string type; |
397 node->GetString("type", &type); | 397 node.GetString("type", &type); |
398 assert(type == "VideoLayer"); | 398 assert(type == "VideoLayer"); |
399 | 399 |
400 if (!InterpretCCData(node, n)) | 400 if (!InterpretCCData(node, n.get())) |
401 return NULL; | 401 return nullptr; |
402 | 402 |
403 return n; | 403 return n; |
404 } | 404 } |
405 | 405 |
406 RenderNode* InterpretImageLayer(base::DictionaryValue* node) { | 406 std::unique_ptr<RenderNode> InterpretImageLayer( |
407 CCNode* n = new CCNode; | 407 const base::DictionaryValue& node) { |
408 if (!InterpretCommonContents(node, n)) | 408 auto n = base::MakeUnique<CCNode>(); |
409 return NULL; | 409 if (!InterpretCommonContents(node, n.get())) |
| 410 return nullptr; |
410 | 411 |
411 if (!VerifyDictionaryEntry(node, "type", base::Value::TYPE_STRING)) { | 412 if (!VerifyDictionaryEntry(node, "type", Value::TYPE_STRING)) |
412 return NULL; | 413 return nullptr; |
413 } | |
414 | 414 |
415 string type; | 415 std::string type; |
416 node->GetString("type", &type); | 416 node.GetString("type", &type); |
417 assert(type == "ImageLayer"); | 417 assert(type == "ImageLayer"); |
418 | 418 |
419 if (!InterpretCCData(node, n)) | 419 if (!InterpretCCData(node, n.get())) |
420 return NULL; | 420 return nullptr; |
421 | 421 |
422 return n; | 422 return n; |
423 } | 423 } |
424 | 424 |
425 RenderNode* InterpretNode(base::DictionaryValue* node) { | 425 std::unique_ptr<RenderNode> InterpretNode(const base::DictionaryValue& node) { |
426 if (!VerifyDictionaryEntry(node, "type", base::Value::TYPE_STRING)) { | 426 if (!VerifyDictionaryEntry(node, "type", Value::TYPE_STRING)) |
427 return NULL; | 427 return nullptr; |
428 } | |
429 | 428 |
430 string type; | 429 std::string type; |
431 node->GetString("type", &type); | 430 node.GetString("type", &type); |
432 if (type == "ContentLayer") | 431 if (type == "ContentLayer") |
433 return InterpretContentLayer(node); | 432 return InterpretContentLayer(node); |
434 if (type == "CanvasLayer") | 433 if (type == "CanvasLayer") |
435 return InterpretCanvasLayer(node); | 434 return InterpretCanvasLayer(node); |
436 if (type == "VideoLayer") | 435 if (type == "VideoLayer") |
437 return InterpretVideoLayer(node); | 436 return InterpretVideoLayer(node); |
438 if (type == "ImageLayer") | 437 if (type == "ImageLayer") |
439 return InterpretImageLayer(node); | 438 return InterpretImageLayer(node); |
440 | 439 |
441 | 440 std::string outjson; |
442 string outjson; | 441 JSONWriter::WriteWithOptions(node, base::JSONWriter::OPTIONS_PRETTY_PRINT, |
443 JSONWriter::WriteWithOptions(*node, base::JSONWriter::OPTIONS_PRETTY_PRINT, | |
444 &outjson); | 442 &outjson); |
445 LOG(ERROR) << "Unrecognized node type! JSON:\n\n" | 443 LOG(ERROR) << "Unrecognized node type! JSON:\n\n" |
446 "-----------------------\n" << | 444 "-----------------------\n" |
447 outjson << | 445 << outjson << "-----------------------"; |
448 "-----------------------"; | |
449 | 446 |
450 return NULL; | 447 return nullptr; |
451 } | 448 } |
452 | 449 |
453 RenderNode* BuildRenderTreeFromFile(const base::FilePath& path) { | 450 std::unique_ptr<RenderNode> BuildRenderTreeFromFile( |
| 451 const base::FilePath& path) { |
454 LOG(INFO) << "Reading " << path.LossyDisplayName(); | 452 LOG(INFO) << "Reading " << path.LossyDisplayName(); |
455 string contents; | 453 std::string contents; |
456 if (!ReadFileToString(path, &contents)) | 454 if (!ReadFileToString(path, &contents)) |
457 return NULL; | 455 return nullptr; |
458 | 456 |
459 int error_code = 0; | 457 int error_code = 0; |
460 string error_message; | 458 std::string error_message; |
461 std::unique_ptr<base::Value> root = JSONReader::ReadAndReturnError( | 459 std::unique_ptr<base::DictionaryValue> root = base::DictionaryValue::From( |
462 contents, base::JSON_ALLOW_TRAILING_COMMAS, &error_code, &error_message); | 460 JSONReader::ReadAndReturnError(contents, base::JSON_ALLOW_TRAILING_COMMAS, |
| 461 &error_code, &error_message)); |
463 if (!root) { | 462 if (!root) { |
464 LOG(ERROR) << "Failed to parse JSON file " << path.LossyDisplayName() << | 463 if (error_code) { |
465 "\n(" << error_message << ")"; | 464 LOG(ERROR) << "Failed to parse JSON file " << path.LossyDisplayName() |
466 return NULL; | 465 << "\n(" << error_message << ")"; |
| 466 } else { |
| 467 LOG(ERROR) << path.LossyDisplayName() |
| 468 << " doesn not encode a JSON dictionary."; |
| 469 } |
| 470 return nullptr; |
467 } | 471 } |
468 | 472 |
469 if (root->IsType(base::Value::TYPE_DICTIONARY)) { | 473 return InterpretContentLayer(*root); |
470 base::DictionaryValue* v = static_cast<base::DictionaryValue*>(root.get()); | |
471 RenderNode* tree = InterpretContentLayer(v); | |
472 return tree; | |
473 } else { | |
474 LOG(ERROR) << path.LossyDisplayName() << | |
475 " doesn not encode a JSON dictionary."; | |
476 return NULL; | |
477 } | |
478 } | 474 } |
479 | 475 |
OLD | NEW |