-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathtest_input.rs
89 lines (74 loc) · 1.66 KB
/
test_input.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#[allow(dead_code)];
#[allow(unused_variable)];
use test_input2::{foo_bar_test_func};
mod test_input2;
fn yada(a:int,c:Foo,b:test_input2::fruit::SomeStruct)->StrBuf { a.to_strbuf() }
fn main() {
use test_input2::fruit::{SomeStruct};
println!("{}", foo_bar_test_func(SomeStruct{red_value:1,green_value:2,blue_value:3},(4,5)).to_str());
let a=Foo{foo_field_1:2};
a.my_method(1);
let c=a_cat(3);
let d=Foo{foo_field_1:a.foo_field_1+2}; a.test();
println!("{}", a.foo_field_1.to_str());
}
struct Foo{foo_field_1:int}
struct Bar(int);
struct Baz(int);
impl Foo {
fn my_method(&self,_:int){ print!("{}", "my_method of foo");}
}
enum Animal {
a_anteater(int),
a_bear(int),
a_cat(int),
a_dog(int),
}
trait Testable
{ fn test(&self);
fn test1(&self);
fn test2(&self);
}
trait DoZ {
fn do_z(&self);
}
impl Testable for Foo {
fn test(&self) {
println!("{}", self.foo_field_1.to_str());
}
fn test1(&self)
{
println!("{}", self.foo_field_1.to_str());
} fn test2(&self)
{
println!("{}", self.foo_field_1.to_str());
}
}
impl DoZ for Foo {
fn do_z(&self) {
println!("{}", self.foo_field_1.to_str());
}
}
trait SuperTraitTest:Testable+DoZ {
}
struct Pair<A,B> { a:A,b:B }
fn gfunc<X:Testable+DoZ>(x:&X) {
let a1=a_anteater(1);
let a2=a_bear(1);
let a3=a_cat(1);
let a4=a_dog(1);
x.test();
x.do_z();
}
struct TraitedStructTest<X> {
x:X
}
fn some2(a:Animal) {
match a {
a_cat(x)=> println!("{}", "cat"),
_ => println!("{}", "not a cat")
}
}
fn foobarbaz()->Pair<Result<int,StrBuf>,Animal> {
Pair{a:Ok(0),b:a_cat(0)}
}