Skip to content

Commit

Permalink
Clarifying documentation for generator
Browse files Browse the repository at this point in the history
  • Loading branch information
alexcrichton authored and Zoxc committed Jul 11, 2017
1 parent 3b23269 commit b593f0a
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions src/doc/unstable-book/src/language-features/generators.md
Original file line number Diff line number Diff line change
Expand Up @@ -128,14 +128,17 @@ closure-like semantics. Namely:
generator progresses.

* Generator literals produce a value with a unique type which implements the
`std::ops::Generator` trait. This allows actual execution of the genrator
`std::ops::Generator` trait. This allows actual execution of the generator
through the `Generator::resume` method as well as also naming it in return
types and such.

* Traits like `Send` and `Sync` are automatically implemented for a `Generator`
depending on the captured variables of the environment. Note, though, that
generators, like closures, do not implement traits like `Copy` or `Clone`
automatically.
depending on the captured variables of the environment. Unlike closures though
generators also depend on variables live across suspension points. This means
that although the ambient environment may be `Send` or `Sync`, the generator
itself may not be due to internal variables live across `yield` points being
not-`Send` or not-`Sync`. Note, though, that generators, like closures, do
not implement traits like `Copy` or `Clone` automatically.

* Whenever a generator is dropped it will drop all captured environment
variables.
Expand Down

0 comments on commit b593f0a

Please sign in to comment.