diff options
| author | John Clements <clements@racket-lang.org> | 2013-02-06 16:20:41 -0800 |
|---|---|---|
| committer | John Clements <clements@racket-lang.org> | 2013-02-09 13:37:04 -0800 |
| commit | 765961438d0a3f8f37f1e38160f6dca04870ae10 (patch) | |
| tree | 1cf41ba7a5fd2df4e63cca3b85c9c2277fc019d6 /src/libsyntax | |
| parent | 19dfec2aaf746535de1521f68421f9980dbf25de (diff) | |
| download | rust-765961438d0a3f8f37f1e38160f6dca04870ae10.tar.gz rust-765961438d0a3f8f37f1e38160f6dca04870ae10.zip | |
fix typos in sample code, add enum to json encoder, add test case
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/ext/auto_encode.rs | 61 |
1 files changed, 50 insertions, 11 deletions
diff --git a/src/libsyntax/ext/auto_encode.rs b/src/libsyntax/ext/auto_encode.rs index 21154bff01e..d8c15d09d98 100644 --- a/src/libsyntax/ext/auto_encode.rs +++ b/src/libsyntax/ext/auto_encode.rs @@ -23,23 +23,23 @@ For example, a type like: would generate two implementations like: - impl<S: Encoder> node_id: Encodable<S> { - fn encode(s: &S) { - do s.emit_struct("Node", 1) { - s.emit_field("id", 0, || s.emit_uint(self)) - } +impl<S: std::serialize::Encoder> Node: Encodable<S> { + fn encode(&self, s: &S) { + do s.emit_struct("Node", 1) { + s.emit_field("id", 0, || s.emit_uint(self.id)) } } +} - impl<D: Decoder> node_id: Decodable { - static fn decode(d: &D) -> Node { - do d.read_struct("Node", 1) { - Node { - id: d.read_field(~"x", 0, || decode(d)) - } +impl<D: Decoder> node_id: Decodable { + static fn decode(d: &D) -> Node { + do d.read_struct("Node", 1) { + Node { + id: d.read_field(~"x", 0, || decode(d)) } } } +} Other interesting scenarios are whe the item has type parameters or references other non-built-in types. A type definition like: @@ -1150,3 +1150,42 @@ fn mk_enum_deser_body( ] ) } + + +#[cfg(test)] +mod test { + use std::serialize::Encodable; + use core::dvec::*; + use util::testing::*; + use core::io; + use core::str; + use std; + + + #[auto_decode] + #[auto_encode] + struct Node {id: uint} + + fn to_json_str (val: Encodable<std::json::Encoder>) -> ~str{ + let bw = @io::BytesWriter {bytes: DVec(), pos: 0}; + val.encode(~std::json::Encoder(bw as io::Writer)); + str::from_bytes(bw.bytes.data) + } + + #[test] fn encode_test () { + check_equal (to_json_str(Node{id:34} as Encodable::<std::json::Encoder>),~"{\"id\":34}"); + } + + #[auto_encode] + enum written { + Book(int), + Magazine(~str) + } + + #[test] fn json_enum_encode_test () { + check_equal (to_json_str(Book(9) as Encodable::<std::json::Encoder>), + ~"[\"Book\",9]"); + check_equal (to_json_str(Magazine(~"Paris Match") as Encodable::<std::json::Encoder>), + ~"[\"Magazine\",\"Paris Match\"]"); + } +} |
