factor out serde2

This commit is contained in:
Erick Tryzelaar
2014-09-01 13:39:00 -07:00
parent 34c38cf3a5
commit 4310645c7e
5 changed files with 155 additions and 144 deletions
+1
View File
@@ -0,0 +1 @@
/target/
+4
View File
@@ -0,0 +1,4 @@
[root]
name = "serde2"
version = "0.1.0"
+11
View File
@@ -0,0 +1,11 @@
[package]
name = "serde2"
version = "0.1.0"
authors = ["Erick Tryzelaar <erick.tryzelaar@gmail.com>"]
[lib]
name = "serde2"
[[bin]]
name = "serde2"
path = "src/bin.rs"
+119
View File
@@ -0,0 +1,119 @@
extern crate serde2;
use std::io;
use std::collections::TreeMap;
use serde2::{Serialize, FormatState, GatherTokens};
///////////////////////////////////////////////////////////////////////////////
struct Foo {
x: int,
y: int,
z: &'static str,
}
impl<S: serde2::SerializeState<R>, R> serde2::Serialize<S, R> for Foo {
fn serialize(&self, state: &mut S) -> R {
state.serialize_struct("Foo", FooSerialize {
value: self,
state: 0,
})
}
}
struct FooSerialize<'a> {
value: &'a Foo,
state: uint,
}
impl<'a, S: serde2::SerializeState<R>, R> serde2::Visitor<S, R> for FooSerialize<'a> {
fn visit(&mut self, state: &mut S) -> Option<R> {
match self.state {
0 => {
self.state += 1;
Some(state.serialize_map_elt(true, "x", &self.value.x))
}
1 => {
self.state += 1;
Some(state.serialize_map_elt(false, "y", &self.value.y))
}
2 => {
self.state += 1;
Some(state.serialize_map_elt(false, "z", &self.value.z))
}
_ => {
None
}
}
}
fn size_hint(&self) -> (uint, Option<uint>) {
let size = 3 - self.state;
(size, Some(size))
}
}
///////////////////////////////////////////////////////////////////////////////
fn main() {
let value = 5i;
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
let value = vec!(1i, 2, 3);
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
let mut value = TreeMap::new();
value.insert("a", 1i);
value.insert("b", 2);
value.insert("c", 3);
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
/*
println!("{}", to_format_vec(&5i));
println!("{}", to_format_string(&5i));
*/
let value = Foo { x: 1, y: 2, z: "abc" };
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
let value = (1i, "abc");
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
}
+20 -144
View File
@@ -4,19 +4,19 @@ use std::collections::TreeMap;
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
trait Serialize<S, R> { pub trait Serialize<S, R> {
fn serialize(&self, state: &mut S) -> R; fn serialize(&self, state: &mut S) -> R;
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
trait Serializer<S, R> { pub trait Serializer<S, R> {
fn hash<T: Serialize<S, R>>(&self, value: &T) -> R; fn hash<T: Serialize<S, R>>(&self, value: &T) -> R;
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
trait Visitor<S, R> { pub trait Visitor<S, R> {
fn visit(&mut self, state: &mut S) -> Option<R>; fn visit(&mut self, state: &mut S) -> Option<R>;
fn size_hint(&self) -> (uint, Option<uint>) { fn size_hint(&self) -> (uint, Option<uint>) {
@@ -24,7 +24,7 @@ trait Visitor<S, R> {
} }
} }
trait SerializeState<R> { pub trait SerializeState<R> {
fn serialize_int(&mut self, value: int) -> R; fn serialize_int(&mut self, value: int) -> R;
fn serialize_str(&mut self, value: &'static str) -> R; fn serialize_str(&mut self, value: &'static str) -> R;
@@ -163,7 +163,7 @@ impl<
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
#[deriving(Show)] #[deriving(Show)]
enum Token { pub enum Token {
Int(int), Int(int),
Str(&'static str), Str(&'static str),
SeqStart(uint), SeqStart(uint),
@@ -172,24 +172,24 @@ enum Token {
End, End,
} }
trait TokenState<R>: SerializeState<R> { pub trait TokenState<R>: SerializeState<R> {
fn serialize(&mut self, token: Token) -> R; fn serialize(&mut self, token: Token) -> R;
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
struct GatherTokens { pub struct GatherTokens {
tokens: Vec<Token>, tokens: Vec<Token>,
} }
impl GatherTokens { impl GatherTokens {
fn new() -> GatherTokens { pub fn new() -> GatherTokens {
GatherTokens { GatherTokens {
tokens: Vec::new(), tokens: Vec::new(),
} }
} }
fn unwrap(self) -> Vec<Token> { pub fn unwrap(self) -> Vec<Token> {
self.tokens self.tokens
} }
} }
@@ -298,16 +298,20 @@ impl SerializeState<()> for GatherTokens {
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
struct FormatState<W: Writer> { pub struct FormatState<W: Writer> {
writer: W, writer: W,
} }
impl<W: Writer> FormatState<W> { impl<W: Writer> FormatState<W> {
fn new(writer: W) -> FormatState<W> { pub fn new(writer: W) -> FormatState<W> {
FormatState { FormatState {
writer: writer, writer: writer,
} }
} }
pub fn unwrap(self) -> W {
self.writer
}
} }
impl<W: Writer> SerializeState<IoResult<()>> for FormatState<W> { impl<W: Writer> SerializeState<IoResult<()>> for FormatState<W> {
@@ -539,17 +543,13 @@ impl SerializeState<Json> for JsonSerializer {
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
/*
pub fn to_format_vec< pub fn to_format_vec<
W: Writer, T: Serialize<FormatState<io::MemWriter>, IoResult<()>>
T: Serialize<FormatState<W>, IoResult<()>>
>(value: &T) -> IoResult<Vec<u8>> { >(value: &T) -> IoResult<Vec<u8>> {
let mut writer = io::MemWriter::new(); let writer = io::MemWriter::new();
{ let mut state = FormatState::new(writer);
let mut w = FormatState::new(writer.by_ref()); try!(value.serialize(&mut state));
try!(value.serialize(&mut w)); Ok(state.unwrap().unwrap())
}
Ok(writer.unwrap())
} }
pub fn to_format_string< pub fn to_format_string<
@@ -558,127 +558,3 @@ pub fn to_format_string<
let vec = try!(to_format_vec(value)); let vec = try!(to_format_vec(value));
Ok(String::from_utf8(vec)) Ok(String::from_utf8(vec))
} }
*/
///////////////////////////////////////////////////////////////////////////////
struct Foo {
x: int,
y: int,
z: &'static str,
}
impl<S: SerializeState<R>, R> Serialize<S, R> for Foo {
fn serialize(&self, state: &mut S) -> R {
let mut x = FooSerialize {
value: self,
state: 0,
foo_state: state,
};
x.foo_state.serialize_struct("Foo", &mut x)
/*
state.serialize_struct("Foo", FooSerialize {
value: self,
state: 0,
foo_state: state,
})
*/
}
}
struct FooSerialize<'a, S> {
value: &'a Foo,
state: uint,
foo_state: &'a mut S,
}
impl<'a, S: SerializeState<R>, R> Visitor<S, R> for FooSerialize<'a, S> {
fn visit(&mut self, state: &mut S) -> Option<R> {
match self.state {
0 => {
self.state += 1;
Some(state.serialize_map_elt(true, "x", &self.value.x))
}
1 => {
self.state += 1;
Some(state.serialize_map_elt(false, "y", &self.value.y))
}
2 => {
self.state += 1;
Some(state.serialize_map_elt(false, "z", &self.value.z))
}
_ => {
None
}
}
}
fn size_hint(&self) -> (uint, Option<uint>) {
let size = 3 - self.state;
(size, Some(size))
}
}
fn main() {
let value = 5i;
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
let value = vec!(1i, 2, 3);
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
let mut value = TreeMap::new();
value.insert("a", 1i);
value.insert("b", 2);
value.insert("c", 3);
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
/*
println!("{}", to_format_vec(&5i));
println!("{}", to_format_string(&5i));
*/
let value = Foo { x: 1, y: 2, z: "abc" };
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
////
let value = (1i, "abc");
let mut s = GatherTokens::new();
value.serialize(&mut s);
println!("tokens: {}", s.unwrap());
value.serialize(&mut FormatState::new(io::stdout())).unwrap();
println!("");
}