From ada9150abf26912478aa6f613602f8ac7ba135e5 Mon Sep 17 00:00:00 2001 From: Patrick Walton Date: Fri, 27 Dec 2013 18:07:12 -0800 Subject: [PATCH] libsyntax: Correctly de-`@mut` the pretty printer writer --- src/libsyntax/ext/expand.rs | 2 +- src/libsyntax/print/pprust.rs | 32 ++++++++++++++------------------ 2 files changed, 15 insertions(+), 19 deletions(-) diff --git a/src/libsyntax/ext/expand.rs b/src/libsyntax/ext/expand.rs index 4df29dc21b14..917b8d2e391c 100644 --- a/src/libsyntax/ext/expand.rs +++ b/src/libsyntax/ext/expand.rs @@ -1319,7 +1319,7 @@ mod test { } fn fake_print_crate(crate: &ast::Crate) { - let out = @mut std::io::stderr() as @mut std::io::Writer; + let mut out = ~std::io::stderr() as ~std::io::Writer; let s = pprust::rust_printer(out, get_ident_interner()); pprust::print_crate_(s, crate); } diff --git a/src/libsyntax/print/pprust.rs b/src/libsyntax/print/pprust.rs index 36a77dfdd89f..45e9641c71b2 100644 --- a/src/libsyntax/print/pprust.rs +++ b/src/libsyntax/print/pprust.rs @@ -122,7 +122,7 @@ pub fn print_crate(cm: @CodeMap, span_diagnostic: @diagnostic::SpanHandler, crate: &ast::Crate, filename: @str, - input: @mut io::Reader, + input: &mut io::Reader, out: ~io::Writer, ann: @pp_ann, is_expanded: bool) { @@ -211,13 +211,8 @@ pub fn fun_to_str(decl: &ast::fn_decl, purity: ast::purity, name: ast::Ident, end(&mut s); // Close the head box end(&mut s); // Close the outer box eof(&mut s.s); - - // XXX(pcwalton): Need checked downcasts. unsafe { - let (_, wr): (uint, ~MemWriter) = cast::transmute(s.s.out); - let result = str::from_utf8_owned(wr.inner_ref().to_owned()); - cast::forget(wr); - result + get_mem_writer(&mut s.s.out) } } @@ -230,13 +225,8 @@ pub fn block_to_str(blk: &ast::Block, intr: @ident_interner) -> ~str { ibox(&mut s, 0u); print_block(&mut s, blk); eof(&mut s.s); - - // XXX(pcwalton): Need checked downcasts. unsafe { - let (_, wr): (uint, ~MemWriter) = cast::transmute(s.s.out); - let result = str::from_utf8_owned(wr.inner_ref().to_owned()); - cast::forget(wr); - result + get_mem_writer(&mut s.s.out) } } @@ -2318,17 +2308,23 @@ pub fn print_string(s: &mut ps, st: &str, style: ast::StrStyle) { word(&mut s.s, st); } +// XXX(pcwalton): A nasty function to extract the string from an `io::Writer` +// that we "know" to be a `MemWriter` that works around the lack of checked +// downcasts. +unsafe fn get_mem_writer(writer: &mut ~io::Writer) -> ~str { + let (_, wr): (uint, ~MemWriter) = cast::transmute_copy(writer); + let result = str::from_utf8_owned(wr.inner_ref().to_owned()); + cast::forget(wr); + result +} + pub fn to_str(t: &T, f: |&mut ps, &T|, intr: @ident_interner) -> ~str { let wr = ~MemWriter::new(); let mut s = rust_printer(wr as ~io::Writer, intr); f(&mut s, t); eof(&mut s.s); - // XXX(pcwalton): Need checked downcasts. unsafe { - let (_, wr): (uint, ~MemWriter) = cast::transmute(s.s.out); - let result = str::from_utf8_owned(wr.inner_ref().to_owned()); - cast::forget(wr); - result + get_mem_writer(&mut s.s.out) } }