Commit 086fec5c authored by Jesse Beder's avatar Jesse Beder
Browse files

Fix formatting when writing \ as a character.

parent 85af926d
...@@ -380,6 +380,8 @@ bool WriteChar(ostream_wrapper& out, char ch) { ...@@ -380,6 +380,8 @@ bool WriteChar(ostream_wrapper& out, char ch) {
out << "\"\\n\""; out << "\"\\n\"";
} else if (ch == '\b') { } else if (ch == '\b') {
out << "\"\\b\""; out << "\"\\b\"";
} else if (ch == '\\') {
out << "\"\\\\\"";
} else if ((0x20 <= ch && ch <= 0x7e) || ch == ' ') { } else if ((0x20 <= ch && ch <= 0x7e) || ch == ' ') {
out << "\"" << ch << "\""; out << "\"" << ch << "\"";
} else { } else {
......
...@@ -970,6 +970,14 @@ TEST_F(EmitterTest, ValueOfDoubleQuote) { ...@@ -970,6 +970,14 @@ TEST_F(EmitterTest, ValueOfDoubleQuote) {
ExpectEmit("foo: \"\\\"\""); ExpectEmit("foo: \"\\\"\"");
} }
TEST_F(EmitterTest, ValueOfBackslash) {
out << YAML::BeginMap;
out << YAML::Key << "foo" << YAML::Value << '\\';
out << YAML::EndMap;
ExpectEmit("foo: \"\\\\\"");
}
class EmitterErrorTest : public ::testing::Test { class EmitterErrorTest : public ::testing::Test {
protected: protected:
void ExpectEmitError(const std::string& expectedError) { void ExpectEmitError(const std::string& expectedError) {
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment