diff options
author | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-01 17:26:06 +0000 |
---|---|---|
committer | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-01 17:26:06 +0000 |
commit | d46d6f3b80099ce0c630185a2e86b649bba49254 (patch) | |
tree | 3467712dd0265f76edf1ae0fcc6da131670bad74 | |
parent | f89a6233760f8ca8033265046ed9ea38bbc20bf9 (diff) | |
download | chromium_src-d46d6f3b80099ce0c630185a2e86b649bba49254.zip chromium_src-d46d6f3b80099ce0c630185a2e86b649bba49254.tar.gz chromium_src-d46d6f3b80099ce0c630185a2e86b649bba49254.tar.bz2 |
Fixes bug where JSON reader errored on reading vertical tabs (\v). The
writer properly escapes a vertical tab, but the readed instead errored
on the vertical this. This resulted in lost bookmarks:(
BUG=3031
TEST=covered by unit tests
Review URL: http://codereview.chromium.org/5628
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2759 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | base/json_reader.cc | 4 | ||||
-rw-r--r-- | base/json_reader_unittest.cc | 4 | ||||
-rw-r--r-- | base/string_escape.cc | 1 |
3 files changed, 7 insertions, 2 deletions
diff --git a/base/json_reader.cc b/base/json_reader.cc index 8d0cab4..c0e019b 100644 --- a/base/json_reader.cc +++ b/base/json_reader.cc @@ -361,6 +361,7 @@ JSONReader::Token JSONReader::ParseStringToken() { case 'n': case 'r': case 't': + case 'v': case '"': break; default: @@ -406,6 +407,9 @@ bool JSONReader::DecodeString(const Token& token, Value** node) { case 't': decoded_str.push_back('\t'); break; + case 'v': + decoded_str.push_back('\v'); + break; case 'x': decoded_str.push_back((HexToInt(*(token.begin + i + 1)) << 4) + diff --git a/base/json_reader_unittest.cc b/base/json_reader_unittest.cc index c2d6a42..4339be1 100644 --- a/base/json_reader_unittest.cc +++ b/base/json_reader_unittest.cc @@ -214,13 +214,13 @@ TEST(JSONReaderTest, Reading) { // Test basic string escapes root = NULL; - ASSERT_TRUE(JSONReader::JsonToValue("\" \\\"\\\\\\/\\b\\f\\n\\r\\t\"", &root, + ASSERT_TRUE(JSONReader::JsonToValue("\" \\\"\\\\\\/\\b\\f\\n\\r\\t\\v\"", &root, false, false)); ASSERT_TRUE(root); ASSERT_TRUE(root->IsType(Value::TYPE_STRING)); str_val.clear(); ASSERT_TRUE(root->GetAsString(&str_val)); - ASSERT_EQ(L" \"\\/\b\f\n\r\t", str_val); + ASSERT_EQ(L" \"\\/\b\f\n\r\t\v", str_val); delete root; // Test hex and unicode escapes including the null character. diff --git a/base/string_escape.cc b/base/string_escape.cc index 5b85e9c..c2fc542 100644 --- a/base/string_escape.cc +++ b/base/string_escape.cc @@ -14,6 +14,7 @@ namespace string_escape { // returns true and appends the escape sequence to |dst|. template<typename CHAR> static bool JavascriptSingleEscapeChar(const CHAR c, std::string* dst) { + // WARNING: if you add a new case here, you need to update the reader as well. switch (c) { case '\b': dst->append("\\b"); |