Merge pull request #3258 from erickt/serialization

Fixing serialization no-implicit-copies warnings, and other misc cleanup
This commit is contained in:
Ben Blum 2012-08-23 09:37:21 -07:00
commit 5d5cfcc005
4 changed files with 33 additions and 38 deletions

View File

@ -284,14 +284,8 @@ impl writer {
self.wr_tagged_bytes(tag_id, &[v as u8]);
}
fn wr_tagged_str(tag_id: uint, v: ~str) {
// Lame: can't use str::as_bytes() here because the resulting
// vector is NULL-terminated. Annoyingly, the underlying
// writer interface doesn't permit us to write a slice of a
// vector. We need first-class slices, I think.
// str::as_bytes(v) {|b| self.wr_tagged_bytes(tag_id, b); }
self.wr_tagged_bytes(tag_id, str::bytes(v));
fn wr_tagged_str(tag_id: uint, v: &str) {
str::byte_slice(v, |b| self.wr_tagged_bytes(tag_id, b));
}
fn wr_bytes(b: &[u8]) {
@ -369,7 +363,7 @@ impl ebml::writer: serialization::serializer {
fn emit_f32(_v: f32) { fail ~"Unimplemented: serializing an f32"; }
fn emit_float(_v: float) { fail ~"Unimplemented: serializing a float"; }
fn emit_str(v: ~str) { self.wr_tagged_str(es_str as uint, v) }
fn emit_str(v: &str) { self.wr_tagged_str(es_str as uint, v) }
fn emit_enum(name: ~str, f: fn()) {
self._emit_label(name);
@ -451,7 +445,7 @@ priv impl ebml_deserializer {
return r_doc;
}
fn push_doc<T: copy>(d: ebml::doc, f: fn() -> T) -> T{
fn push_doc<T>(d: ebml::doc, f: fn() -> T) -> T{
let old_parent = self.parent;
let old_pos = self.pos;
self.parent = d;
@ -505,13 +499,13 @@ impl ebml_deserializer: serialization::deserializer {
fn read_str() -> ~str { ebml::doc_as_str(self.next_doc(es_str)) }
// Compound types:
fn read_enum<T:copy>(name: ~str, f: fn() -> T) -> T {
fn read_enum<T>(name: ~str, f: fn() -> T) -> T {
debug!{"read_enum(%s)", name};
self._check_label(name);
self.push_doc(self.next_doc(es_enum), f)
}
fn read_enum_variant<T:copy>(f: fn(uint) -> T) -> T {
fn read_enum_variant<T>(f: fn(uint) -> T) -> T {
debug!{"read_enum_variant()"};
let idx = self._next_uint(es_enum_vid);
debug!{" idx=%u", idx};
@ -520,12 +514,12 @@ impl ebml_deserializer: serialization::deserializer {
}
}
fn read_enum_variant_arg<T:copy>(idx: uint, f: fn() -> T) -> T {
fn read_enum_variant_arg<T>(idx: uint, f: fn() -> T) -> T {
debug!{"read_enum_variant_arg(idx=%u)", idx};
f()
}
fn read_vec<T:copy>(f: fn(uint) -> T) -> T {
fn read_vec<T>(f: fn(uint) -> T) -> T {
debug!{"read_vec()"};
do self.push_doc(self.next_doc(es_vec)) {
let len = self._next_uint(es_vec_len);
@ -534,38 +528,38 @@ impl ebml_deserializer: serialization::deserializer {
}
}
fn read_vec_elt<T:copy>(idx: uint, f: fn() -> T) -> T {
fn read_vec_elt<T>(idx: uint, f: fn() -> T) -> T {
debug!{"read_vec_elt(idx=%u)", idx};
self.push_doc(self.next_doc(es_vec_elt), f)
}
fn read_box<T:copy>(f: fn() -> T) -> T {
fn read_box<T>(f: fn() -> T) -> T {
debug!{"read_box()"};
f()
}
fn read_uniq<T:copy>(f: fn() -> T) -> T {
fn read_uniq<T>(f: fn() -> T) -> T {
debug!{"read_uniq()"};
f()
}
fn read_rec<T:copy>(f: fn() -> T) -> T {
fn read_rec<T>(f: fn() -> T) -> T {
debug!{"read_rec()"};
f()
}
fn read_rec_field<T:copy>(f_name: ~str, f_idx: uint, f: fn() -> T) -> T {
fn read_rec_field<T>(f_name: ~str, f_idx: uint, f: fn() -> T) -> T {
debug!{"read_rec_field(%s, idx=%u)", f_name, f_idx};
self._check_label(f_name);
f()
}
fn read_tup<T:copy>(sz: uint, f: fn() -> T) -> T {
fn read_tup<T>(sz: uint, f: fn() -> T) -> T {
debug!{"read_tup(sz=%u)", sz};
f()
}
fn read_tup_elt<T:copy>(idx: uint, f: fn() -> T) -> T {
fn read_tup_elt<T>(idx: uint, f: fn() -> T) -> T {
debug!{"read_tup_elt(idx=%u)", idx};
f()
}

View File

@ -63,7 +63,7 @@ impl Writer: serializer {
self.write_str(fmt!{"%?_f32", v});
}
fn emit_str(v: ~str) {
fn emit_str(v: &str) {
self.write_str(fmt!{"%?", v});
}
@ -127,4 +127,4 @@ impl Writer: serializer {
if idx > 0u { self.write_str(~", "); }
f();
}
}
}

View File

@ -23,7 +23,7 @@ trait serializer {
fn emit_float(v: float);
fn emit_f64(v: f64);
fn emit_f32(v: f32);
fn emit_str(v: ~str);
fn emit_str(v: &str);
// Compound types:
fn emit_enum(name: ~str, f: fn());
@ -65,17 +65,17 @@ trait deserializer {
fn read_float() -> float;
// Compound types:
fn read_enum<T:copy>(name: ~str, f: fn() -> T) -> T;
fn read_enum_variant<T:copy>(f: fn(uint) -> T) -> T;
fn read_enum_variant_arg<T:copy>(idx: uint, f: fn() -> T) -> T;
fn read_vec<T:copy>(f: fn(uint) -> T) -> T;
fn read_vec_elt<T:copy>(idx: uint, f: fn() -> T) -> T;
fn read_box<T:copy>(f: fn() -> T) -> T;
fn read_uniq<T:copy>(f: fn() -> T) -> T;
fn read_rec<T:copy>(f: fn() -> T) -> T;
fn read_rec_field<T:copy>(f_name: ~str, f_idx: uint, f: fn() -> T) -> T;
fn read_tup<T:copy>(sz: uint, f: fn() -> T) -> T;
fn read_tup_elt<T:copy>(idx: uint, f: fn() -> T) -> T;
fn read_enum<T>(name: ~str, f: fn() -> T) -> T;
fn read_enum_variant<T>(f: fn(uint) -> T) -> T;
fn read_enum_variant_arg<T>(idx: uint, f: fn() -> T) -> T;
fn read_vec<T>(f: fn(uint) -> T) -> T;
fn read_vec_elt<T>(idx: uint, f: fn() -> T) -> T;
fn read_box<T>(f: fn() -> T) -> T;
fn read_uniq<T>(f: fn() -> T) -> T;
fn read_rec<T>(f: fn() -> T) -> T;
fn read_rec_field<T>(f_name: ~str, f_idx: uint, f: fn() -> T) -> T;
fn read_tup<T>(sz: uint, f: fn() -> T) -> T;
fn read_tup_elt<T>(idx: uint, f: fn() -> T) -> T;
}
// ___________________________________________________________________________
@ -201,7 +201,7 @@ fn deserialize_i64<D: deserializer>(d: D) -> i64 {
d.read_i64()
}
fn serialize_str<S: serializer>(s: S, v: ~str) {
fn serialize_str<S: serializer>(s: S, v: &str) {
s.emit_str(v);
}

View File

@ -583,8 +583,9 @@ fn parse_pretty(sess: session, &&name: ~str) -> pp_mode {
~"expanded,identified" => ppm_expanded_identified,
~"identified" => ppm_identified,
_ => {
sess.fatal(~"argument to `pretty` must be one of `normal`, `typed`, \
or `identified`");
sess.fatal(~"argument to `pretty` must be one of `normal`, \
`expanded`, `typed`, `identified`, \
or `expanded,identified`");
}
}
}