Chromium Code Reviews| 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 |