rust/src/test/run-pass/auto-encode.rs

172 lines
4.0 KiB
Rust
Raw Normal View History

// Copyright 2013-2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
// ignore-test FIXME(#5121)
extern crate rbml;
extern crate serialize;
extern crate time;
2012-09-18 14:08:42 -05:00
// These tests used to be separate files, but I wanted to refactor all
2013-01-29 01:54:39 -06:00
// the common code.
2012-09-18 14:08:42 -05:00
use std::collections::{HashMap, HashSet};
use rbml::reader as EBReader;
use rbml::writer as EBWriter;
use std::cmp::Eq;
use std::cmp;
use std::io;
use serialize::{Decodable, Encodable};
2012-09-18 14:08:42 -05:00
fn test_rbml<'a, 'b, A:
Eq +
Encodable<EBWriter::Encoder<'a>> +
Decodable<EBReader::Decoder<'b>>
>(a1: &A) {
let mut wr = Vec::new();
let mut rbml_w = EBwriter::Encoder::new(&mut wr);
a1.encode(&mut rbml_w);
let d: serialize::rbml::Doc<'a> = EBDoc::new(&wr);
let mut decoder: EBReader::Decoder<'a> = EBreader::Decoder::new(d);
let a2: A = Decodable::decode(&mut decoder);
2013-03-28 20:39:09 -05:00
assert!(*a1 == a2);
2012-09-18 14:08:42 -05:00
}
#[derive(Decodable, Encodable)]
enum Expr {
Val(uint),
Plus(@Expr, @Expr),
Minus(@Expr, @Expr)
}
impl cmp::Eq for Expr {
fn eq(&self, other: &Expr) -> bool {
match *self {
Val(e0a) => {
match *other {
Val(e0b) => e0a == e0b,
_ => false
}
}
Plus(e0a, e1a) => {
match *other {
Plus(e0b, e1b) => e0a == e0b && e1a == e1b,
_ => false
}
}
Minus(e0a, e1a) => {
match *other {
Minus(e0b, e1b) => e0a == e0b && e1a == e1b,
_ => false
}
}
}
}
fn ne(&self, other: &Expr) -> bool { !(*self).eq(other) }
}
impl cmp::Eq for Point {
fn eq(&self, other: &Point) -> bool {
2012-09-18 14:08:42 -05:00
self.x == other.x && self.y == other.y
}
fn ne(&self, other: &Point) -> bool { !(*self).eq(other) }
2012-09-18 14:08:42 -05:00
}
impl<T:cmp::Eq> cmp::Eq for Quark<T> {
fn eq(&self, other: &Quark<T>) -> bool {
match *self {
Top(ref q) => {
match *other {
Top(ref r) => q == r,
Bottom(_) => false
}
},
Bottom(ref q) => {
match *other {
Top(_) => false,
Bottom(ref r) => q == r
}
},
2012-09-18 14:08:42 -05:00
}
}
fn ne(&self, other: &Quark<T>) -> bool { !(*self).eq(other) }
2012-09-18 14:08:42 -05:00
}
impl cmp::Eq for CLike {
fn eq(&self, other: &CLike) -> bool {
(*self) as int == *other as int
2012-09-18 14:08:42 -05:00
}
fn ne(&self, other: &CLike) -> bool { !self.eq(other) }
2012-09-18 14:08:42 -05:00
}
#[derive(Decodable, Encodable, Eq)]
struct Spanned<T> {
lo: uint,
hi: uint,
node: T,
}
2012-09-18 14:08:42 -05:00
#[derive(Decodable, Encodable)]
struct SomeStruct { v: Vec<uint> }
2012-09-18 14:08:42 -05:00
#[derive(Decodable, Encodable)]
2012-10-01 13:35:27 -05:00
struct Point {x: uint, y: uint}
2012-09-18 14:08:42 -05:00
#[derive(Decodable, Encodable)]
2012-09-18 14:08:42 -05:00
enum Quark<T> {
Top(T),
Bottom(T)
}
#[derive(Decodable, Encodable)]
2012-09-18 14:08:42 -05:00
enum CLike { A, B, C }
pub fn main() {
let a = &Plus(@Minus(@Val(3_usize), @Val(10_usize)), @Plus(@Val(22_usize), @Val(5_usize)));
test_rbml(a);
let a = &Spanned {lo: 0_usize, hi: 5_usize, node: 22_usize};
test_rbml(a);
let a = &Point {x: 3_usize, y: 5_usize};
test_rbml(a);
let a = &Top(22_usize);
test_rbml(a);
let a = &Bottom(222_usize);
test_rbml(a);
let a = &A;
test_rbml(a);
let a = &B;
test_rbml(a);
let a = &time::now();
test_rbml(a);
test_rbml(&1.0f32);
test_rbml(&1.0f64);
test_rbml(&'a');
let mut a = HashMap::new();
test_rbml(&a);
a.insert(1, 2);
test_rbml(&a);
let mut a = HashSet::new();
test_rbml(&a);
a.insert(1);
test_rbml(&a);
2012-09-18 14:08:42 -05:00
}