diff options
author | fangjue23303@gmail.com <fangjue23303@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-02-05 07:31:50 +0000 |
---|---|---|
committer | fangjue23303@gmail.com <fangjue23303@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-02-05 07:31:50 +0000 |
commit | c472a6c30c0384ede6b8ec950054f6f6e17b0b10 (patch) | |
tree | 7f070126dafb42fe4599daeec8554ace588f8ca4 /base/json | |
parent | b4b26c6204d2e7653120267efefd2e2eeccf6733 (diff) | |
download | chromium_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.cc | 4 | ||||
-rw-r--r-- | base/json/json_parser_unittest.cc | 17 |
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)); |