Change discussion of derive/annotations/traits to match reorg

This commit is contained in:
Carol (Nichols || Goulding) 2016-07-21 21:53:08 -04:00
parent afbbb0de4a
commit ca7a5f39d6

View File

@ -210,7 +210,7 @@ Our function signature for `distance()` now says exactly what we mean: it
calculates the distance between two `Point`s. And rather than `0` and `1`, calculates the distance between two `Point`s. And rather than `0` and `1`,
weve got back our `x` and `y`. This is a win for clarity. weve got back our `x` and `y`. This is a win for clarity.
Theres one other thing thats a bit strange here, this annotation on our Theres one other thing thats a bit strange here, this stuff above the
`struct` declaration: `struct` declaration:
```rust,ignore ```rust,ignore
@ -218,7 +218,10 @@ Theres one other thing thats a bit strange here, this annotation on our
struct Point { struct Point {
``` ```
We havent yet talked about traits, but we did talk about `Debug` when we This is an annotation that tells the compiler our struct should get some
discussed arrays. This `derive` attribute allows us to tweak the behavior of default behavior for the `Debug`, `Copy`, and `Clone` traits. We talked about
our `Point`. In this case, we are opting into copy semantics, and everything `Debug` when we discussed arrays-- this lets us print out the `struct` and all
that implements `Copy` must implement `Clone`. its fields when we use an instance of the struct with `println!`'s `{:?}`. We
talked about marking that types can be `Copy` and `Clone`-able in Chapter XX
when we discussed ownership. We'll continue exploring annotations and the
behaviors you can `derive` in Chapter XX.