summaryrefslogtreecommitdiffstats
path: root/base/json
diff options
context:
space:
mode:
authorfangjue23303@gmail.com <fangjue23303@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98>2013-02-05 07:31:50 +0000
committerfangjue23303@gmail.com <fangjue23303@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98>2013-02-05 07:31:50 +0000
commitc472a6c30c0384ede6b8ec950054f6f6e17b0b10 (patch)
tree7f070126dafb42fe4599daeec8554ace588f8ca4 /base/json
parentb4b26c6204d2e7653120267efefd2e2eeccf6733 (diff)
downloadchromium_src-c472a6c30c0384ede6b8ec950054f6f6e17b0b10.zip
chromium_src-c472a6c30c0384ede6b8ec950054f6f6e17b0b10.tar.gz
chromium_src-c472a6c30c0384ede6b8ec950054f6f6e17b0b10.tar.bz2
Recognize "\r\n" (Windows) line endings in base::JSONParser so that line numbers in error reports won't confuse users.
BUG=167424 TEST=Unit tests Review URL: https://chromiumcodereview.appspot.com/12026035 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@180625 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/json')
-rw-r--r--base/json/json_parser.cc4
-rw-r--r--base/json/json_parser_unittest.cc17
2 files changed, 18 insertions, 3 deletions
diff --git a/base/json/json_parser.cc b/base/json/json_parser.cc
index 4c03a98..429c77a 100644
--- a/base/json/json_parser.cc
+++ b/base/json/json_parser.cc
@@ -404,7 +404,9 @@ void JSONParser::EatWhitespaceAndComments() {
case '\r':
case '\n':
index_last_line_ = index_;
- ++line_number_;
+ // Don't increment line_number_ twice for "\r\n".
+ if (!(*pos_ == '\n' && pos_ > start_pos_ && *(pos_ - 1) == '\r'))
+ ++line_number_;
// Fall through.
case ' ':
case '\t':
diff --git a/base/json/json_parser_unittest.cc b/base/json/json_parser_unittest.cc
index 8ee886b..74e2026 100644
--- a/base/json/json_parser_unittest.cc
+++ b/base/json/json_parser_unittest.cc
@@ -210,8 +210,8 @@ TEST_F(JSONParserTest, ErrorMessages) {
EXPECT_EQ(0, error_code);
// Test line and column counting
- const char* big_json = "[\n0,\n1,\n2,\n3,4,5,6 7,\n8,\n9\n]";
- // error here ---------------------------------^
+ const char big_json[] = "[\n0,\n1,\n2,\n3,4,5,6 7,\n8,\n9\n]";
+ // error here ----------------------------------^
root.reset(JSONReader::ReadAndReturnError(big_json, JSON_PARSE_RFC,
&error_code, &error_message));
EXPECT_FALSE(root.get());
@@ -219,6 +219,19 @@ TEST_F(JSONParserTest, ErrorMessages) {
error_message);
EXPECT_EQ(JSONReader::JSON_SYNTAX_ERROR, error_code);
+ error_code = 0;
+ error_message = "";
+ // Test line and column counting with "\r\n" line ending
+ const char big_json_crlf[] =
+ "[\r\n0,\r\n1,\r\n2,\r\n3,4,5,6 7,\r\n8,\r\n9\r\n]";
+ // error here ----------------------^
+ root.reset(JSONReader::ReadAndReturnError(big_json_crlf, JSON_PARSE_RFC,
+ &error_code, &error_message));
+ EXPECT_FALSE(root.get());
+ EXPECT_EQ(JSONParser::FormatErrorMessage(5, 10, JSONReader::kSyntaxError),
+ error_message);
+ EXPECT_EQ(JSONReader::JSON_SYNTAX_ERROR, error_code);
+
// Test each of the error conditions
root.reset(JSONReader::ReadAndReturnError("{},{}", JSON_PARSE_RFC,
&error_code, &error_message));