implement Writer for Vec<u8>
The trait has an obvious, sensible implementation directly on vectors so the MemWriter wrapper is unnecessary. This will halt the trend towards providing all of the vector methods on MemWriter along with eliminating the noise caused by conversions between the two types. It also provides the useful default Writer methods on Vec<u8>. After the type is removed and code has been migrated, it would make sense to add a new implementation of MemWriter with seeking support. The simple use cases can be covered with vectors alone, and ones with the need for seeks can use a new MemWriter implementation.
This commit is contained in:
@@ -33,7 +33,7 @@ use print::pp;
|
||||
use ptr::P;
|
||||
|
||||
use std::ascii;
|
||||
use std::io::{IoResult, MemWriter};
|
||||
use std::io::IoResult;
|
||||
use std::io;
|
||||
use std::mem;
|
||||
|
||||
@@ -169,17 +169,17 @@ impl<'a> State<'a> {
|
||||
|
||||
pub fn to_string(f: |&mut State| -> IoResult<()>) -> String {
|
||||
use std::raw::TraitObject;
|
||||
let mut s = rust_printer(box MemWriter::new());
|
||||
let mut s = rust_printer(box Vec::new());
|
||||
f(&mut s).unwrap();
|
||||
eof(&mut s.s).unwrap();
|
||||
let wr = unsafe {
|
||||
// FIXME(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
|
||||
// that we "know" to be a `Vec<u8>` that works around the lack of checked
|
||||
// downcasts.
|
||||
let obj: &TraitObject = mem::transmute(&s.s.out);
|
||||
mem::transmute::<*mut (), &MemWriter>(obj.data)
|
||||
mem::transmute::<*mut (), &Vec<u8>>(obj.data)
|
||||
};
|
||||
String::from_utf8(wr.get_ref().to_vec()).unwrap()
|
||||
String::from_utf8(wr.clone()).unwrap()
|
||||
}
|
||||
|
||||
pub fn binop_to_string(op: BinOpToken) -> &'static str {
|
||||
|
||||
Reference in New Issue
Block a user