Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Associated type bounds: Fix desugaring + other house keeping #2

Merged
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 24 additions & 14 deletions text/0000-associated-type-bounds.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,9 @@
[summary]: #summary

Introduce the bound form `MyTrait<AssociatedType: Bounds>`, permitted anywhere
a bound of the form `MyTrait<AssociatedType = T>` would be allowed. This form
desugars to `MyTrait<AssociatedType = impl Bounds>`.
a bound of the form `MyTrait<AssociatedType = T>` would be allowed. The bound
`T: Trait<AssociatedType: Bounds>` desugars to the bounds `T: Trait` and
`<T as Trait>::AssociatedType: Bounds`.

# Motivation
[motivation]: #motivation
Expand Down Expand Up @@ -85,21 +86,29 @@ impl<I: Clone + Iterator<Item: Clone>> Clone for Peekable<I> {
# Reference-level explanation
[reference-level-explanation]: #reference-level-explanation

The surface syntax `Trait<AssociatedType: Bounds>` should desugar to
`Trait<AssociatedType = impl Bounds>` anywhere it appears. This syntax
does not introduce any new semantics that the availability of
`impl Bounds` does not already introduce.
The surface syntax `T: Trait<AssociatedType: Bounds>` should always desugar
to a pair of bounds: `T: Trait` and `<T as Trait>::AssociatedType: Bounds`.
Rust currently allows both of those bounds anywhere a bound can currently appear;
the new syntax does not introduce any new semantics.

Additionally, the surface syntax `impl Trait<AssociatedType: Bounds>` turns
into a named type variable `T`, universal or existential depending on context,
with the usual bound `T: Trait` along with the added bound
`<T as Trait>::AssociatedType: Bounds`.

Meanwhile, the surface syntax `dyn Trait<AssociatedType: Bounds>` desugars into
`dyn Trait<AssociatedType = T>` where `T` is a named type variable `T` with the
bound `T: Bounds`.

# Drawbacks
[drawbacks]: #drawbacks

With the introduction of the `impl Trait` syntax, Rust code can already
express this using the desugared form. This proposal just introduces a
simpler surface syntax that parallels other uses of bounds. As always,
when introducing new syntactic forms, an increased burden is put on
developers to know about and understand those forms, and this proposal
is no different. However, we believe that the parallel to the use of bounds
elsewhere makes this new syntax immediately recognizable and understandable.
Rust code can already express this using the desugared form. This proposal
just introduces a simpler surface syntax that parallels other uses of bounds.
As always, when introducing new syntactic forms, an increased burden is put on
developers to know about and understand those forms, and this proposal is no
different. However, we believe that the parallel to the use of bounds elsewhere
makes this new syntax immediately recognizable and understandable.

# Rationale and alternatives
[alternatives]: #alternatives
Expand All @@ -113,4 +122,5 @@ The introduced form in this RFC is comparatively both shorter and clearer.
# Unresolved questions
[unresolved]: #unresolved-questions

- Does allowing this for `dyn` trait objects introduce any unforseen issues?
- Does allowing this for `dyn` trait objects introduce any unforseen issues?
This can be resolved during stabilization.