auto merge of #6398 : osaut/rust/master, r=bstrie

I have replaced io::println by println in the tutorial as I do not think it is needed anymore since it is already included in prelude.rs.
This commit is contained in:
bors 2013-05-11 15:10:44 -07:00
commit 9ee8d506d9

View File

@ -129,7 +129,7 @@ we have a file `hello.rs` containing this program:
~~~~
fn main() {
io::println("hello?");
println("hello?");
}
~~~~
@ -139,12 +139,12 @@ Windows) which, upon running, will likely do exactly what you expect.
The Rust compiler tries to provide useful information when it encounters an
error. If you introduce an error into the program (for example, by changing
`io::println` to some nonexistent function), and then compile it, you'll see
`println` to some nonexistent function), and then compile it, you'll see
an error message like this:
~~~~ {.notrust}
hello.rs:2:4: 2:16 error: unresolved name: io::print_with_unicorns
hello.rs:2 io::print_with_unicorns("hello?");
hello.rs:2:4: 2:16 error: unresolved name: print_with_unicorns
hello.rs:2 print_with_unicorns("hello?");
^~~~~~~~~~~~~~~~~~~~~~~
~~~~
@ -227,7 +227,7 @@ let hi = "hi";
let mut count = 0;
while count < 10 {
io::println(fmt!("count: %?", count));
println(fmt!("count: %?", count));
count += 1;
}
~~~~
@ -400,10 +400,10 @@ don't match the types of the arguments.
~~~~
# let mystery_object = ();
io::println(fmt!("%s is %d", "the answer", 43));
println(fmt!("%s is %d", "the answer", 43));
// %? will conveniently print any type
io::println(fmt!("what is this thing: %?", mystery_object));
println(fmt!("what is this thing: %?", mystery_object));
~~~~
[pf]: http://en.cppreference.com/w/cpp/io/c/fprintf
@ -422,11 +422,11 @@ compulsory, an `if` can have an optional `else` clause, and multiple
~~~~
if false {
io::println("that's odd");
println("that's odd");
} else if true {
io::println("right");
println("right");
} else {
io::println("neither true nor false");
println("neither true nor false");
}
~~~~
@ -454,10 +454,10 @@ executes its corresponding arm.
~~~~
# let my_number = 1;
match my_number {
0 => io::println("zero"),
1 | 2 => io::println("one or two"),
3..10 => io::println("three to ten"),
_ => io::println("something else")
0 => println("zero"),
1 | 2 => println("one or two"),
3..10 => println("three to ten"),
_ => println("something else")
}
~~~~
@ -483,8 +483,8 @@ commas are optional.
~~~
# let my_number = 1;
match my_number {
0 => { io::println("zero") }
_ => { io::println("something else") }
0 => { println("zero") }
_ => { println("something else") }
}
~~~
@ -560,7 +560,7 @@ let mut x = 5;
loop {
x += x - 3;
if x % 5 == 0 { break; }
io::println(int::to_str(x));
println(int::to_str(x));
}
~~~~
@ -614,8 +614,8 @@ origin.y += 1.0; // ERROR: assigning to immutable field
# struct Point { x: float, y: float }
# let mypoint = Point { x: 0.0, y: 0.0 };
match mypoint {
Point { x: 0.0, y: yy } => { io::println(yy.to_str()); }
Point { x: xx, y: yy } => { io::println(xx.to_str() + " " + yy.to_str()); }
Point { x: 0.0, y: yy } => { println(yy.to_str()); }
Point { x: xx, y: yy } => { println(xx.to_str() + " " + yy.to_str()); }
}
~~~~
@ -630,7 +630,7 @@ reuses the field name as the binding name.
# struct Point { x: float, y: float }
# let mypoint = Point { x: 0.0, y: 0.0 };
match mypoint {
Point { x, _ } => { io::println(x.to_str()) }
Point { x, _ } => { println(x.to_str()) }
}
~~~
@ -1231,7 +1231,7 @@ something silly like
~~~
# struct Point { x: float, y: float }
let point = &@~Point { x: 10f, y: 20f };
io::println(fmt!("%f", point.x));
println(fmt!("%f", point.x));
~~~
The indexing operator (`[]`) also auto-dereferences.
@ -1373,7 +1373,6 @@ and [`core::str`]. Here are some examples.
[`core::str`]: core/str.html
~~~
# use core::io::println;
# enum Crayon {
# Almond, AntiqueBrass, Apricot,
# Aquamarine, Asparagus, AtomicTangerine,
@ -1428,7 +1427,6 @@ Rust also supports _closures_, functions that can access variables in
the enclosing scope.
~~~~
# use println = core::io::println;
fn call_closure_with_ten(b: &fn(int)) { b(10); }
let captured_var = 20;
@ -1490,7 +1488,7 @@ fn mk_appender(suffix: ~str) -> @fn(~str) -> ~str {
fn main() {
let shout = mk_appender(~"!");
io::println(shout(~"hey ho, let's go"));
println(shout(~"hey ho, let's go"));
}
~~~~
@ -1632,7 +1630,6 @@ And using this function to iterate over a vector:
~~~~
# use each = core::vec::each;
# use println = core::io::println;
each([2, 4, 8, 5, 16], |n| {
if *n % 2 != 0 {
println("found odd number!");
@ -1649,7 +1646,6 @@ to the next iteration, write `loop`.
~~~~
# use each = core::vec::each;
# use println = core::io::println;
for each([2, 4, 8, 5, 16]) |n| {
if *n % 2 != 0 {
println("found odd number!");
@ -1982,7 +1978,7 @@ struct TimeBomb {
impl Drop for TimeBomb {
fn finalize(&self) {
for old_iter::repeat(self.explosivity) {
io::println("blam!");
println("blam!");
}
}
}
@ -2014,11 +2010,11 @@ and `~str`.
~~~~
# trait Printable { fn print(&self); }
impl Printable for int {
fn print(&self) { io::println(fmt!("%d", *self)) }
fn print(&self) { println(fmt!("%d", *self)) }
}
impl Printable for ~str {
fn print(&self) { io::println(*self) }
fn print(&self) { println(*self) }
}
# 1.print();
@ -2307,7 +2303,7 @@ mod farm {
}
fn main() {
io::println(farm::chicken());
println(farm::chicken());
}
~~~~
@ -2507,7 +2503,7 @@ pub fn explore() -> &str { "world" }
~~~~ {.xfail-test}
// main.rs
extern mod world;
fn main() { io::println(~"hello " + world::explore()); }
fn main() { println(~"hello " + world::explore()); }
~~~~
Now compile and run like this (adjust to your platform if necessary):