diff options
| author | Erick Tryzelaar <erick.tryzelaar@gmail.com> | 2012-10-13 09:11:33 -0700 |
|---|---|---|
| committer | Niko Matsakis <niko@alum.mit.edu> | 2012-10-15 08:25:23 -0700 |
| commit | ab89b5c294ac511d4d58809f9f20dfe4f2c8fe52 (patch) | |
| tree | e1374cc163794698bda233cdba3b32416820ab7b /src/libstd | |
| parent | 07edf9036715bde27cc7bbc0feb3ee6e461130da (diff) | |
| download | rust-ab89b5c294ac511d4d58809f9f20dfe4f2c8fe52.tar.gz rust-ab89b5c294ac511d4d58809f9f20dfe4f2c8fe52.zip | |
libstd: make Serializer a trait-level typaram
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/json.rs | 28 | ||||
| -rw-r--r-- | src/libstd/serialization.rs | 487 |
2 files changed, 515 insertions, 0 deletions
diff --git a/src/libstd/json.rs b/src/libstd/json.rs index 0d3391c1867..d170255b565 100644 --- a/src/libstd/json.rs +++ b/src/libstd/json.rs @@ -273,6 +273,7 @@ pub impl PrettySerializer: serialization::Serializer { } } +#[cfg(stage0)] pub impl Json: serialization::Serializable { fn serialize<S: serialization::Serializer>(&self, s: &S) { match *self { @@ -296,6 +297,33 @@ pub impl Json: serialization::Serializable { } } +#[cfg(stage1)] +#[cfg(stage2)] +pub impl< + S: serialization::Serializer +> Json: serialization::Serializable<S> { + fn serialize(&self, s: &S) { + match *self { + Number(v) => v.serialize(s), + String(ref v) => v.serialize(s), + Boolean(v) => v.serialize(s), + List(v) => v.serialize(s), + Object(ref v) => { + do s.emit_rec || { + let mut idx = 0; + for v.each |key, value| { + do s.emit_field(*key, idx) { + value.serialize(s); + } + idx += 1; + } + } + }, + Null => s.emit_nil(), + } + } +} + /// Serializes a json value into a io::writer pub fn to_writer(wr: io::Writer, json: &Json) { json.serialize(&Serializer(wr)) diff --git a/src/libstd/serialization.rs b/src/libstd/serialization.rs index b7cf09cc6aa..9df2a326a84 100644 --- a/src/libstd/serialization.rs +++ b/src/libstd/serialization.rs @@ -92,6 +92,8 @@ pub trait Deserializer { fn read_tup_elt<T>(&self, idx: uint, f: fn() -> T) -> T; } +#[cfg(stage0)] +pub mod traits { pub trait Serializable { fn serialize<S: Serializer>(&self, s: &S); } @@ -561,3 +563,488 @@ pub impl<D: Deserializer> D: DeserializerHelpers { } } } +} + +#[cfg(stage1)] +#[cfg(stage2)] +pub mod traits { +pub trait Serializable<S: Serializer> { + fn serialize(&self, s: &S); +} + +pub trait Deserializable<D: Deserializer> { + static fn deserialize(&self, d: &D) -> self; +} + +pub impl<S: Serializer> uint: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_uint(*self) } +} + +pub impl<D: Deserializer> uint: Deserializable<D> { + static fn deserialize(&self, d: &D) -> uint { + d.read_uint() + } +} + +pub impl<S: Serializer> u8: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_u8(*self) } +} + +pub impl<D: Deserializer> u8: Deserializable<D> { + static fn deserialize(&self, d: &D) -> u8 { + d.read_u8() + } +} + +pub impl<S: Serializer> u16: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_u16(*self) } +} + +pub impl<D: Deserializer> u16: Deserializable<D> { + static fn deserialize(&self, d: &D) -> u16 { + d.read_u16() + } +} + +pub impl<S: Serializer> u32: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_u32(*self) } +} + +pub impl<D: Deserializer> u32: Deserializable<D> { + static fn deserialize(&self, d: &D) -> u32 { + d.read_u32() + } +} + +pub impl<S: Serializer> u64: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_u64(*self) } +} + +pub impl<D: Deserializer> u64: Deserializable<D> { + static fn deserialize(&self, d: &D) -> u64 { + d.read_u64() + } +} + +pub impl<S: Serializer> int: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_int(*self) } +} + +pub impl<D: Deserializer> int: Deserializable<D> { + static fn deserialize(&self, d: &D) -> int { + d.read_int() + } +} + +pub impl<S: Serializer> i8: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_i8(*self) } +} + +pub impl<D: Deserializer> i8: Deserializable<D> { + static fn deserialize(&self, d: &D) -> i8 { + d.read_i8() + } +} + +pub impl<S: Serializer> i16: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_i16(*self) } +} + +pub impl<D: Deserializer> i16: Deserializable<D> { + static fn deserialize(&self, d: &D) -> i16 { + d.read_i16() + } +} + +pub impl<S: Serializer> i32: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_i32(*self) } +} + +pub impl<D: Deserializer> i32: Deserializable<D> { + static fn deserialize(&self, d: &D) -> i32 { + d.read_i32() + } +} + +pub impl<S: Serializer> i64: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_i64(*self) } +} + +pub impl<D: Deserializer> i64: Deserializable<D> { + static fn deserialize(&self, d: &D) -> i64 { + d.read_i64() + } +} + +pub impl<S: Serializer> &str: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_borrowed_str(*self) } +} + +pub impl<S: Serializer> ~str: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_owned_str(*self) } +} + +pub impl<D: Deserializer> ~str: Deserializable<D> { + static fn deserialize(&self, d: &D) -> ~str { + d.read_owned_str() + } +} + +pub impl<S: Serializer> @str: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_managed_str(*self) } +} + +pub impl<D: Deserializer> @str: Deserializable<D> { + static fn deserialize(&self, d: &D) -> @str { + d.read_managed_str() + } +} + +pub impl<S: Serializer> float: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_float(*self) } +} + +pub impl<D: Deserializer> float: Deserializable<D> { + static fn deserialize(&self, d: &D) -> float { + d.read_float() + } +} + +pub impl<S: Serializer> f32: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_f32(*self) } +} + +pub impl<D: Deserializer> f32: Deserializable<D> { + static fn deserialize(&self, d: &D) -> f32 { + d.read_f32() } +} + +pub impl<S: Serializer> f64: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_f64(*self) } +} + +pub impl<D: Deserializer> f64: Deserializable<D> { + static fn deserialize(&self, d: &D) -> f64 { + d.read_f64() + } +} + +pub impl<S: Serializer> bool: Serializable<S> { + fn serialize(&self, s: &S) { s.emit_bool(*self) } +} + +pub impl<D: Deserializer> bool: Deserializable<D> { + static fn deserialize(&self, d: &D) -> bool { + d.read_bool() + } +} + +pub impl<S: Serializer> (): Serializable<S> { + fn serialize(&self, s: &S) { s.emit_nil() } +} + +pub impl<D: Deserializer> (): Deserializable<D> { + static fn deserialize(&self, d: &D) -> () { + d.read_nil() + } +} + +pub impl<S: Serializer, T: Serializable<S>> &T: Serializable<S> { + fn serialize(&self, s: &S) { + s.emit_borrowed(|| (**self).serialize(s)) + } +} + +pub impl<S: Serializer, T: Serializable<S>> ~T: Serializable<S> { + fn serialize(&self, s: &S) { + s.emit_owned(|| (**self).serialize(s)) + } +} + +pub impl<D: Deserializer, T: Deserializable<D>> ~T: Deserializable<D> { + static fn deserialize(&self, d: &D) -> ~T { + d.read_owned(|| ~deserialize(d)) + } +} + +pub impl<S: Serializer, T: Serializable<S>> @T: Serializable<S> { + fn serialize(&self, s: &S) { + s.emit_managed(|| (**self).serialize(s)) + } +} + +pub impl<D: Deserializer, T: Deserializable<D>> @T: Deserializable<D> { + static fn deserialize(&self, d: &D) -> @T { + d.read_managed(|| @deserialize(d)) + } +} + +pub impl<S: Serializer, T: Serializable<S>> &[T]: Serializable<S> { + fn serialize(&self, s: &S) { + do s.emit_borrowed_vec(self.len()) { + for self.eachi |i, e| { + s.emit_vec_elt(i, || e.serialize(s)) + } + } + } +} + +pub impl<S: Serializer, T: Serializable<S>> ~[T]: Serializable<S> { + fn serialize(&self, s: &S) { + do s.emit_owned_vec(self.len()) { + for self.eachi |i, e| { + s.emit_vec_elt(i, || e.serialize(s)) + } + } + } +} + +pub impl<D: Deserializer, T: Deserializable<D>> ~[T]: Deserializable<D> { + static fn deserialize(&self, d: &D) -> ~[T] { + do d.read_owned_vec |len| { + do vec::from_fn(len) |i| { + d.read_vec_elt(i, || deserialize(d)) + } + } + } +} + +pub impl<S: Serializer, T: Serializable<S>> @[T]: Serializable<S> { + fn serialize(&self, s: &S) { + do s.emit_managed_vec(self.len()) { + for self.eachi |i, e| { + s.emit_vec_elt(i, || e.serialize(s)) + } + } + } +} + +pub impl<D: Deserializer, T: Deserializable<D>> @[T]: Deserializable<D> { + static fn deserialize(&self, d: &D) -> @[T] { + do d.read_managed_vec |len| { + do at_vec::from_fn(len) |i| { + d.read_vec_elt(i, || deserialize(d)) + } + } + } +} + +pub impl<S: Serializer, T: Serializable<S>> Option<T>: Serializable<S> { + fn serialize(&self, s: &S) { + do s.emit_enum(~"option") { + match *self { + None => do s.emit_enum_variant(~"none", 0u, 0u) { + }, + + Some(ref v) => do s.emit_enum_variant(~"some", 1u, 1u) { + s.emit_enum_variant_arg(0u, || v.serialize(s)) + } + } + } + } +} + +pub impl<D: Deserializer, T: Deserializable<D>> Option<T>: Deserializable<D> { + static fn deserialize(&self, d: &D) -> Option<T> { + do d.read_enum(~"option") { + do d.read_enum_variant |i| { + match i { + 0 => None, + 1 => Some(d.read_enum_variant_arg(0u, || deserialize(d))), + _ => fail(#fmt("Bad variant for option: %u", i)) + } + } + } + } +} + +pub impl< + S: Serializer, + T0: Serializable<S>, + T1: Serializable<S> +> (T0, T1): Serializable<S> { + fn serialize(&self, s: &S) { + match *self { + (ref t0, ref t1) => { + do s.emit_tup(2) { + s.emit_tup_elt(0, || t0.serialize(s)); + s.emit_tup_elt(1, || t1.serialize(s)); + } + } + } + } +} + +pub impl< + D: Deserializer, + T0: Deserializable<D>, + T1: Deserializable<D> +> (T0, T1): Deserializable<D> { + static fn deserialize(&self, d: &D) -> (T0, T1) { + do d.read_tup(2) { + ( + d.read_tup_elt(0, || deserialize(d)), + d.read_tup_elt(1, || deserialize(d)) + ) + } + } +} + +pub impl< + S: Serializer, + T0: Serializable<S>, + T1: Serializable<S>, + T2: Serializable<S> +> (T0, T1, T2): Serializable<S> { + fn serialize(&self, s: &S) { + match *self { + (ref t0, ref t1, ref t2) => { + do s.emit_tup(3) { + s.emit_tup_elt(0, || t0.serialize(s)); + s.emit_tup_elt(1, || t1.serialize(s)); + s.emit_tup_elt(2, || t2.serialize(s)); + } + } + } + } +} + +pub impl< + D: Deserializer, + T0: Deserializable<D>, + T1: Deserializable<D>, + T2: Deserializable<D> +> (T0, T1, T2): Deserializable<D> { + static fn deserialize(&self, d: &D) -> (T0, T1, T2) { + do d.read_tup(3) { + ( + d.read_tup_elt(0, || deserialize(d)), + d.read_tup_elt(1, || deserialize(d)), + d.read_tup_elt(2, || deserialize(d)) + ) + } + } +} + +pub impl< + S: Serializer, + T0: Serializable<S>, + T1: Serializable<S>, + T2: Serializable<S>, + T3: Serializable<S> +> (T0, T1, T2, T3): Serializable<S> { + fn serialize(&self, s: &S) { + match *self { + (ref t0, ref t1, ref t2, ref t3) => { + do s.emit_tup(4) { + s.emit_tup_elt(0, || t0.serialize(s)); + s.emit_tup_elt(1, || t1.serialize(s)); + s.emit_tup_elt(2, || t2.serialize(s)); + s.emit_tup_elt(3, || t3.serialize(s)); + } + } + } + } +} + +pub impl< + D: Deserializer, + T0: Deserializable<D>, + T1: Deserializable<D>, + T2: Deserializable<D>, + T3: Deserializable<D> +> (T0, T1, T2, T3): Deserializable<D> { + static fn deserialize(&self, d: &D) -> (T0, T1, T2, T3) { + do d.read_tup(4) { + ( + d.read_tup_elt(0, || deserialize(d)), + d.read_tup_elt(1, || deserialize(d)), + d.read_tup_elt(2, || deserialize(d)), + d.read_tup_elt(3, || deserialize(d)) + ) + } + } +} + +pub impl< + S: Serializer, + T0: Serializable<S>, + T1: Serializable<S>, + T2: Serializable<S>, + T3: Serializable<S>, + T4: Serializable<S> +> (T0, T1, T2, T3, T4): Serializable<S> { + fn serialize(&self, s: &S) { + match *self { + (ref t0, ref t1, ref t2, ref t3, ref t4) => { + do s.emit_tup(5) { + s.emit_tup_elt(0, || t0.serialize(s)); + s.emit_tup_elt(1, || t1.serialize(s)); + s.emit_tup_elt(2, || t2.serialize(s)); + s.emit_tup_elt(3, || t3.serialize(s)); + s.emit_tup_elt(4, || t4.serialize(s)); + } + } + } + } +} + +pub impl< + D: Deserializer, + T0: Deserializable<D>, + T1: Deserializable<D>, + T2: Deserializable<D>, + T3: Deserializable<D>, + T4: Deserializable<D> +> (T0, T1, T2, T3, T4): Deserializable<D> { + static fn deserialize(&self, d: &D) + -> (T0, T1, T2, T3, T4) { + do d.read_tup(5) { + ( + d.read_tup_elt(0, || deserialize(d)), + d.read_tup_elt(1, || deserialize(d)), + d.read_tup_elt(2, || deserialize(d)), + d.read_tup_elt(3, || deserialize(d)), + d.read_tup_elt(4, || deserialize(d)) + ) + } + } +} + +// ___________________________________________________________________________ +// Helper routines +// +// In some cases, these should eventually be coded as traits. + +pub trait SerializerHelpers { + fn emit_from_vec<T>(&self, v: ~[T], f: fn(v: &T)); +} + +pub impl<S: Serializer> S: SerializerHelpers { + fn emit_from_vec<T>(&self, v: ~[T], f: fn(v: &T)) { + do self.emit_owned_vec(v.len()) { + for v.eachi |i, e| { + do self.emit_vec_elt(i) { + f(e) + } + } + } + } +} + +pub trait DeserializerHelpers { + fn read_to_vec<T>(&self, f: fn() -> T) -> ~[T]; +} + +pub impl<D: Deserializer> D: DeserializerHelpers { + fn read_to_vec<T>(&self, f: fn() -> T) -> ~[T] { + do self.read_owned_vec |len| { + do vec::from_fn(len) |i| { + self.read_vec_elt(i, || f()) + } + } + } +} +} + +pub use traits::*; |
