diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-04-18 17:33:47 -0700 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-04-18 17:37:27 -0700 |
| commit | 55310acbca84abfbb3636440a849a2e77d03992c (patch) | |
| tree | 72569692265094424ad9610ef77214f8861d0d71 /src/libstd | |
| parent | b75683cadf6c4c55360202cd6a0106be80532451 (diff) | |
| download | rust-55310acbca84abfbb3636440a849a2e77d03992c.tar.gz rust-55310acbca84abfbb3636440a849a2e77d03992c.zip | |
std: Fix demangling with middle special chars
Previously, symbols with rust escape sequences (denoted with dollar signs) weren't demangled if the escape sequence showed up in the middle. This alters the printing loop to look through the entire string for dollar characters.
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/rt/backtrace.rs | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/src/libstd/rt/backtrace.rs b/src/libstd/rt/backtrace.rs index bf8c15c20ab..c3bf7a6d12a 100644 --- a/src/libstd/rt/backtrace.rs +++ b/src/libstd/rt/backtrace.rs @@ -109,7 +109,7 @@ fn demangle(writer: &mut Writer, s: &str) -> IoResult<()> { let i: uint = from_str(s.slice_to(s.len() - rest.len())).unwrap(); s = rest.slice_from(i); rest = rest.slice_to(i); - loop { + while rest.len() > 0 { if rest.starts_with("$") { macro_rules! demangle( ($($pat:expr => $demangled:expr),*) => ({ @@ -144,8 +144,12 @@ fn demangle(writer: &mut Writer, s: &str) -> IoResult<()> { "$x5d" => "]" ) } else { - try!(writer.write_str(rest)); - break; + let idx = match rest.find('$') { + None => rest.len(), + Some(i) => i, + }; + try!(writer.write_str(rest.slice_to(idx))); + rest = rest.slice_from(idx); } } } @@ -774,4 +778,10 @@ mod test { t!("_ZN8$UP$test4foobE", "~test::foob"); t!("_ZN8$x20test4foobE", " test::foob"); } + + #[test] + fn demangle_many_dollars() { + t!("_ZN12test$x20test4foobE", "test test::foob"); + t!("_ZN12test$UP$test4foobE", "test~test::foob"); + } } |
