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 "base/test/values_test_util.h" | 5 #include "base/test/values_test_util.h" |
6 | 6 |
7 #include "base/json/json_reader.h" | 7 #include "base/json/json_reader.h" |
8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
10 #include "base/values.h" | 10 #include "base/values.h" |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
67 scoped_ptr<Value> result(base::JSONReader::ReadAndReturnError( | 67 scoped_ptr<Value> result(base::JSONReader::ReadAndReturnError( |
68 json, base::JSON_ALLOW_TRAILING_COMMAS, | 68 json, base::JSON_ALLOW_TRAILING_COMMAS, |
69 NULL, &error_msg)); | 69 NULL, &error_msg)); |
70 if (!result) { | 70 if (!result) { |
71 ADD_FAILURE() << "Failed to parse \"" << json << "\": " << error_msg; | 71 ADD_FAILURE() << "Failed to parse \"" << json << "\": " << error_msg; |
72 result.reset(Value::CreateNullValue()); | 72 result.reset(Value::CreateNullValue()); |
73 } | 73 } |
74 return result.Pass(); | 74 return result.Pass(); |
75 } | 75 } |
76 | 76 |
77 scoped_ptr<DictionaryValue> ParseJsonDictionaryWithSingleQuotes( | |
Paweł Hajdan Jr.
2014/03/03 22:50:47
Why not let the caller do things this code is doin
scheib
2014/03/03 22:56:43
To avoid code duplication and increase test readab
not at google - send to devlin
2014/03/03 22:59:04
FWIW this is a function I've also often very much
Paweł Hajdan Jr.
2014/03/05 03:52:56
Extracting this to a function is fine. Having that
scheib
2014/03/05 04:49:41
Fair point. Here's my justification: It is highly
| |
78 base::StringPiece json) { | |
79 std::string json_single_quotes_replaced = json.as_string(); | |
Jeffrey Yasskin
2014/03/04 01:41:48
Since you're making a copy here anyway, you should
scheib
2014/03/04 15:34:31
Done.
| |
80 std::replace(json_single_quotes_replaced.begin(), | |
81 json_single_quotes_replaced.end(), | |
82 '\'', | |
83 '"'); | |
84 std::string error_msg; | |
85 scoped_ptr<Value> result( | |
86 base::JSONReader::ReadAndReturnError(json_single_quotes_replaced, | |
87 base::JSON_ALLOW_TRAILING_COMMAS, | |
88 NULL, | |
89 &error_msg)); | |
90 scoped_ptr<base::DictionaryValue> result_dict; | |
91 if (result && result->IsType(base::Value::TYPE_DICTIONARY)) { | |
92 result_dict.reset(static_cast<DictionaryValue*>(result.release())); | |
93 } else { | |
94 ADD_FAILURE() << "Failed to parse \"" << json << "\": " << error_msg; | |
95 result_dict.reset(new base::DictionaryValue()); | |
96 } | |
97 return result_dict.Pass(); | |
98 } | |
99 | |
77 } // namespace test | 100 } // namespace test |
78 } // namespace base | 101 } // namespace base |
OLD | NEW |