2015-01-08 10:27:03 -08:00
|
|
|
% Comments
|
2014-12-02 09:20:48 -05:00
|
|
|
|
|
|
|
Now that we have some functions, it's a good idea to learn about comments.
|
|
|
|
Comments are notes that you leave to other programmers to help explain things
|
|
|
|
about your code. The compiler mostly ignores them.
|
|
|
|
|
2015-01-08 16:52:50 -08:00
|
|
|
Rust has two kinds of comments that you should care about: *line comments*
|
|
|
|
and *doc comments*.
|
2014-12-02 09:20:48 -05:00
|
|
|
|
|
|
|
```{rust}
|
|
|
|
// Line comments are anything after '//' and extend to the end of the line.
|
|
|
|
|
|
|
|
let x = 5; // this is also a line comment.
|
|
|
|
|
|
|
|
// If you have a long explanation for something, you can put line comments next
|
|
|
|
// to each other. Put a space between the // and your comment so that it's
|
|
|
|
// more readable.
|
|
|
|
```
|
|
|
|
|
|
|
|
The other kind of comment is a doc comment. Doc comments use `///` instead of
|
|
|
|
`//`, and support Markdown notation inside:
|
|
|
|
|
|
|
|
```{rust}
|
|
|
|
/// `hello` is a function that prints a greeting that is personalized based on
|
|
|
|
/// the name given.
|
|
|
|
///
|
|
|
|
/// # Arguments
|
|
|
|
///
|
|
|
|
/// * `name` - The name of the person you'd like to greet.
|
|
|
|
///
|
2015-03-11 21:11:40 -04:00
|
|
|
/// # Examples
|
2014-12-02 09:20:48 -05:00
|
|
|
///
|
|
|
|
/// ```rust
|
|
|
|
/// let name = "Steve";
|
|
|
|
/// hello(name); // prints "Hello, Steve!"
|
|
|
|
/// ```
|
|
|
|
fn hello(name: &str) {
|
|
|
|
println!("Hello, {}!", name);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
When writing doc comments, adding sections for any arguments, return values,
|
2015-01-10 23:10:00 +01:00
|
|
|
and providing some examples of usage is very, very helpful. Don't worry about
|
|
|
|
the `&str`, we'll get to it soon.
|
2014-12-02 09:20:48 -05:00
|
|
|
|
2015-01-31 12:27:57 +01:00
|
|
|
You can use the [`rustdoc`](documentation.html) tool to generate HTML documentation
|
2014-12-02 09:20:48 -05:00
|
|
|
from these doc comments.
|