Skip to content

Commit

Permalink
Merge pull request #493 from RadicalZephyr/clarifications
Browse files Browse the repository at this point in the history
Clarifications
  • Loading branch information
Centril authored Feb 22, 2019
2 parents 404235e + 83cb560 commit c3dd948
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 13 deletions.
4 changes: 2 additions & 2 deletions src/items/generics.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
Functions, type aliases, structs, enumerations, unions, traits and
implementations may be *parameterized* by types and lifetimes. These parameters
are listed in angle <span class="parenthetical">brackets (`<...>`)</span>,
usually immediately after and before its definition the name of the item. For
usually immediately after the name of the item and before its definition. For
implementations, which don't have a name, they come directly after `impl`.
Lifetime parameters must be declared before type parameters. Some examples of
items with type and lifetime parameters:
Expand Down Expand Up @@ -57,7 +57,7 @@ referred to with path syntax.
> _ForLifetimes_ :\
> &nbsp;&nbsp; `for` `<` [_LifetimeParams_](#type-and-lifetime-parameters) `>`
*Where clauses* provide an another way to specify bounds on type and lifetime
*Where clauses* provide another way to specify bounds on type and lifetime
parameters as well as a way to specify bounds on types that aren't type
parameters.

Expand Down
50 changes: 39 additions & 11 deletions src/items/implementations.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,25 +50,50 @@ bracketed set of associable items.
The nominal type is called the _implementing type_ and the associable items are
the _associated items_ to the implementing type.

Inherent implementations associate the contained items to the implementing type.
The associated item has a path of a path to the implementing type followed by
the associate item's path component. Inherent implementations cannot contain
associated type aliases.
Inherent implementations associate the contained items to the
implementing type. Inherent implementations can contain [associated
functions] (including methods) and [associated constants]. They cannot
contain associated type aliases.

The [path] to an associated item is any path to the implementing type,
followed by the associated item's identifier as the final path
component.

A type can also have multiple inherent implementations. An implementing type
must be defined within the same crate as the original type definition.

```rust
struct Point {x: i32, y: i32}
``` rust
pub mod color {
pub struct Color(pub u8, pub u8, pub u8);

impl Color {
pub const WHITE: Color = Color(255, 255, 255);
}
}

impl Point {
fn log(&self) {
println!("Point is at ({}, {})", self.x, self.y);
mod values {
use super::color::Color;
impl Color {
pub fn red() -> Color {
Color(255, 0, 0)
}
}
}

let my_point = Point {x: 10, y:11};
my_point.log();
pub use self::color::Color;
fn main() {
// Actual path to the implementing type and impl in the same module.
color::Color::WHITE;

// Impl blocks in different modules are still accessed through a path to the type.
color::Color::red();

// Re-exported paths to the implementing type also work.
Color::red();

// Does not work, because use in `values` is not pub.
// values::Color::red();
}
```

## Trait Implementations
Expand Down Expand Up @@ -191,9 +216,12 @@ attributes].
[_Visibility_]: visibility-and-privacy.html
[_WhereClause_]: items/generics.html#where-clauses
[trait]: items/traits.html
[associated functions]: items/associated-items.html#associated-functions-and-methods
[associated constants]: items/associated-items.html#associated-constants
[attributes]: attributes.html
[`cfg`]: conditional-compilation.html
[`deprecated`]: attributes.html#deprecation
[`doc`]: attributes.html#documentation
[path]: paths.html
[the lint check attributes]: attributes.html#lint-check-attributes
[Unsafe traits]: items/traits.html#unsafe-traits

0 comments on commit c3dd948

Please sign in to comment.