]> git.lizzy.rs Git - rust.git/blob - tests/target/multiple.rs
Merge pull request #175 from marcusklaas/assignment
[rust.git] / tests / target / multiple.rs
1 // Test of lots of random stuff.
2 // FIXME split this into multiple, self-contained tests.
3
4
5 #[attr1]
6 extern crate foo;
7 #[attr2]
8 #[attr3]
9 extern crate foo;
10 #[attr1]
11 extern crate foo;
12 #[attr2]
13 #[attr3]
14 extern crate foo;
15
16 use std::cell::*;
17 use std::{self, any, ascii, borrow, boxed, char, borrow, boxed, char, borrow, borrow, boxed, char,
18           borrow, boxed, char, borrow, boxed, char, borrow, boxed, char, borrow, boxed, char,
19           borrow, boxed, char, borrow, boxed, char, borrow, boxed, char};
20
21 mod doc;
22 mod other;
23
24
25 // sfdgfffffffffffffffffffffffffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffffffffffffff
26
27 fn foo(a: isize, b: u32 /* blah blah */, c: f64) {
28
29 }
30
31 fn foo()
32     where 'a: 'b,
33           for<'a> D<'b>: 'a
34 {
35     hello!()
36 }
37
38 fn baz<'a: 'b, // comment on 'a
39        T: SomsssssssssssssssssssssssssssssssssssssssssssssssssssssseType /* comment on T */>
40     (a: A,
41      b: B, // comment on b
42      c: C)
43      -> Bob {
44     #[attr1]
45     extern crate foo;
46     #[attr2]
47     #[attr3]
48     extern crate foo;
49     #[attr1]
50     extern crate foo;
51     #[attr2]
52     #[attr3]
53     extern crate foo;
54 }
55
56 #[rustfmt_skip]
57 fn qux(a: dadsfa,   // Comment 1
58        b: sdfasdfa, // Comment 2
59        c: dsfdsafa) // Comment 3
60 {
61
62 }
63
64 /// Blah blah blah.
65 impl Bar {
66     fn foo(&mut self,
67            a: sdfsdfcccccccccccccccccccccccccccccccccccccccccccccccccc, /* commen
68                                                                          * t on a */
69            b: sdfasdfsdfasfs /* closing comment */)
70            -> isize {
71     }
72
73     /// Blah blah blah.
74     pub fn f2(self) {
75         (foo, bar)
76     }
77
78     #[an_attribute]
79     fn f3(self) -> Dog {
80     }
81 }
82
83 /// The `nodes` and `edges` method each return instantiations of
84 /// `Cow<[T]>` to leave implementers the freedom to create
85
86 /// entirely new vectors or to pass back slices into internally owned
87 /// vectors.
88 pub trait GraphWalk<'a, N, E> {
89     /// Returns all the nodes in this graph.
90     fn nodes(&'a self) -> Nodes<'a, N>;
91     /// Returns all of the edges in this graph.
92     fn edges(&'a self) -> Edges<'a, E>;
93     /// The source node for `edge`.
94     fn source(&'a self, edge: &E) -> N;
95     /// The target node for `edge`.
96     fn target(&'a self, edge: &E) -> N;
97 }
98
99 /// A Doc comment
100 #[AnAttribute]
101 pub struct Foo {
102     #[rustfmt_skip]
103     f :   SomeType, // Comment beside a field
104     f: SomeType, // Comment beside a field
105     // Comment on a field
106     g: SomeOtherType,
107     /// A doc comment on a field
108     h: AThirdType,
109 }
110
111 struct Bar;
112
113 // With a where clause and generics.
114 pub struct Foo<'a, Y: Baz>
115     where X: Whatever
116 {
117     f: SomeType, // Comment beside a field
118 }
119
120 fn main() {
121     for i in 0i32..4 {
122         println!("{}", i);
123     }
124
125
126     while true {
127         hello();
128     }
129
130     let rc = Cell::new(42usize,
131                        42usize,
132                        Cell::new(42usize,
133                                  remaining_widthremaining_widthremaining_widthremaining_width),
134                        42usize);
135     let rc = RefCell::new(42usize, remaining_width, remaining_width);  // a comment
136     let x = "Hello!!!!!!!!! abcd  abcd abcd abcd abcd abcd\n abcd abcd abcd abcd abcd abcd abcd \
137              abcd abcd abcd  abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd \
138              abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd abcd \
139              abcd abcd";
140 }