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

Rework trait parameter patterns #1771

Merged
merged 1 commit into from
Apr 1, 2025

Conversation

ehuss
Copy link
Contributor

@ehuss ehuss commented Mar 27, 2025

This updates the description of trait parameter patterns, primarily to shift it to the style where the main text describes the behavior in the current edition, and changes in the edition are moved to separate edition blocks.

The specific changes:

  • Rework the edition presentation (as per our style guide).
  • Try to use more consistent wording.
  • Add examples.
  • Rename some of the rules to switch to the updated edition style, and try to be a little clearer about their intent.
  • Change the way it refers to "methods". The reference used to define methods as a separate kind of associated item, but we changed it so that functions allow an optional SelfParam, and methods aren't as special as they used to be. This text was still written assuming the previous presentation.

@rustbot rustbot added the S-waiting-on-review Status: The marked PR is awaiting review from a maintainer label Mar 27, 2025
Comment on lines +336 to +353
r[items.traits.params.restriction-patterns.edition2018]
> [!EDITION-2018]
> Prior to the 2018 edition, parameters in associated functions with a body are limited to the following kinds of patterns:
>
> * [IDENTIFIER]
> * `mut` [IDENTIFIER]
> * [`_`][WildcardPattern]
> * `&` [IDENTIFIER]
> * `&&` [IDENTIFIER]
>
> ```rust,edition2015,compile_fail,E0642
> // 2015 Edition
> trait T {
> fn f1((a, b): (i32, i32)) {} // ERROR: pattern not allowed
> }
> ```
>
> Beginning in 2018, all irrefutable patterns are allowed as described in [items.traits.params.patterns-with-body].
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's a thought for another PR, but I wonder whether it'd be useful for us to link from these edition differences blocks to the relevant chapter of the edition guide.

* `&&` [IDENTIFIER]
```rust,compile_fail,E0642
trait T {
fn f2(&x: &i32); // ERROR: Patterns aren't allowed in functions without bodies
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should be lowercased to match the others. I'll fix.

@traviscross traviscross force-pushed the trait-pattern-edition-rework branch from e9890c7 to a319552 Compare April 1, 2025 21:35
> ```rust,edition2015
> // 2015 Edition
> trait T {
> fn f(i32); // Parameter identifiers are not required.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Other things here are going with the // OK: .. pattern, so I'll edit to match that.

This updates the description of trait parameter patterns, primarily to
shift it to the style where the main text describes the behavior in the
current edition, and changes in the edition are moved to separate
edition blocks.

The specific changes:

- Rework the edition presentation (as per our style guide).
- Try to use more consistent wording.
- Add examples.
- Rename some of the rules to switch to the updated edition style, and
  try to be a little clearer about their intent.
- Change the way it refers to "methods". The reference used to define
  methods as a separate kind of associated item, but we changed it so
  that functions allow an optional _SelfParam_, and methods aren't as
  special as they used to be. This text was still written assuming the
  previous presentation.
@traviscross traviscross force-pushed the trait-pattern-edition-rework branch from a319552 to 7cdad30 Compare April 1, 2025 21:37
@traviscross traviscross added this pull request to the merge queue Apr 1, 2025
Merged via the queue into rust-lang:master with commit d1e0e0a Apr 1, 2025
5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-review Status: The marked PR is awaiting review from a maintainer
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants