rust/src/test/run-pass/trait-cast.rs

49 lines
1.1 KiB
Rust
Raw Normal View History

// Test cyclic detector when using trait instances.
enum Tree = TreeR;
type TreeR = @{
2012-08-20 12:23:37 -07:00
mut left: Option<Tree>,
mut right: Option<Tree>,
val: to_str
};
trait to_str {
fn to_str() -> ~str;
}
2012-08-20 12:23:37 -07:00
impl <T: to_str> Option<T>: to_str {
fn to_str() -> ~str {
2012-08-06 12:34:08 -07:00
match self {
2012-08-20 12:23:37 -07:00
None => { ~"none" }
Some(t) => { ~"some(" + t.to_str() + ~")" }
}
}
}
2012-08-07 18:10:06 -07:00
impl int: to_str {
fn to_str() -> ~str { int::str(self) }
}
2012-08-07 18:10:06 -07:00
impl Tree: to_str {
fn to_str() -> ~str {
let l = self.left, r = self.right;
2012-08-22 17:24:52 -07:00
fmt!("[%s, %s, %s]", self.val.to_str(),
l.to_str(), r.to_str())
}
}
fn foo<T: to_str>(x: T) -> ~str { x.to_str() }
fn main() {
2012-08-20 12:23:37 -07:00
let t1 = Tree(@{mut left: None,
mut right: None,
val: 1 as to_str });
2012-08-20 12:23:37 -07:00
let t2 = Tree(@{mut left: Some(t1),
mut right: Some(t1),
val: 2 as to_str });
let expected = ~"[2, some([1, none, none]), some([1, none, none])]";
assert t2.to_str() == expected;
assert foo(t2 as to_str) == expected;
2012-08-20 12:23:37 -07:00
t1.left = Some(t2); // create cycle
}