From f87578d9fbf37f76fc1ccd3eb92ef24f8b2a0b31 Mon Sep 17 00:00:00 2001 From: Daniel Micay Date: Sat, 7 Sep 2013 14:52:31 -0400 Subject: [PATCH] fix repr of strings/chars with quotes Closes #8743 --- src/libstd/repr.rs | 27 ++++++++++++++++++++++----- 1 file changed, 22 insertions(+), 5 deletions(-) diff --git a/src/libstd/repr.rs b/src/libstd/repr.rs index c03d7bdf6a7f5..9873317738d6a 100644 --- a/src/libstd/repr.rs +++ b/src/libstd/repr.rs @@ -178,7 +178,7 @@ impl<'self> ReprVisitor<'self> { pub fn write_escaped_slice(&mut self, slice: &str) { self.writer.write(['"' as u8]); for ch in slice.iter() { - self.write_escaped_char(ch); + self.write_escaped_char(ch, true); } self.writer.write(['"' as u8]); } @@ -230,14 +230,26 @@ impl<'self> ReprVisitor<'self> { v.fill, inner) } - fn write_escaped_char(&mut self, ch: char) { + fn write_escaped_char(&mut self, ch: char, is_str: bool) { match ch { '\t' => self.writer.write("\\t".as_bytes()), '\r' => self.writer.write("\\r".as_bytes()), '\n' => self.writer.write("\\n".as_bytes()), '\\' => self.writer.write("\\\\".as_bytes()), - '\'' => self.writer.write("\\'".as_bytes()), - '"' => self.writer.write("\\\"".as_bytes()), + '\'' => { + if is_str { + self.writer.write("'".as_bytes()) + } else { + self.writer.write("\\'".as_bytes()) + } + } + '"' => { + if is_str { + self.writer.write("\\\"".as_bytes()) + } else { + self.writer.write("\"".as_bytes()) + } + } '\x20'..'\x7e' => self.writer.write([ch as u8]), _ => { do char::escape_unicode(ch) |c| { @@ -274,7 +286,7 @@ impl<'self> TyVisitor for ReprVisitor<'self> { fn visit_char(&mut self) -> bool { do self.get:: |this, &ch| { this.writer.write(['\'' as u8]); - this.write_escaped_char(ch); + this.write_escaped_char(ch, false); this.writer.write(['\'' as u8]); } } @@ -684,6 +696,11 @@ fn test_repr() { exact_test(&(10u64, ~"hello"), "(10u64, ~\"hello\")"); + exact_test(&'\'', "'\\''"); + exact_test(&'"', "'\"'"); + exact_test(&("'"), "\"'\""); + exact_test(&("\""), "\"\\\"\""); + exact_test(&println, "fn(&str)"); exact_test(&swap::, "fn(&mut int, &mut int)"); exact_test(&is_alphabetic, "fn(char) -> bool");