From efc2cf3ee5e77f0781e1ab0d371fc1d9cdaa232e Mon Sep 17 00:00:00 2001 From: Matthew Woodcraft Date: Sun, 9 Jan 2022 17:32:34 +0000 Subject: [PATCH 1/2] Document the 2021 edition changes to macros-by-example `pat` metavariables --- src/macros-by-example.md | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/macros-by-example.md b/src/macros-by-example.md index 25671c4f5..4bdab6b03 100644 --- a/src/macros-by-example.md +++ b/src/macros-by-example.md @@ -123,7 +123,7 @@ fragment specifiers are: * `stmt`: a [_Statement_] without the trailing semicolon (except for item statements that require semicolons) * `pat_param`: a [_PatternNoTopAlt_] - * `pat`: equivalent to `pat_param` + * `pat`: at least any [_PatternNoTopAlt_], and possibly more depending on edition * `expr`: an [_Expression_] * `ty`: a [_Type_] * `ident`: an [IDENTIFIER_OR_KEYWORD] or [RAW_IDENTIFIER] @@ -140,6 +140,10 @@ the syntax element that matched them. The keyword metavariable `$crate` can be used to refer to the current crate; see [Hygiene] below. Metavariables can be transcribed more than once or not at all. +> **Edition Differences**: Starting with the 2021 edition, `pat` fragment-specifiers match top-level or-patterns (that is, they accept [_Pattern_]). +> +> Before the 2021 edition, they match exactly the same fragments as `pat_param` (that is, they accept [_PatternNoTopAlt_]). + ## Repetitions In both the matcher and transcriber, repetitions are indicated by placing the @@ -451,7 +455,8 @@ Matchers like `$i:expr,` or `$i:expr;` would be legal, however, because `,` and `;` are legal expression separators. The specific rules are: * `expr` and `stmt` may only be followed by one of: `=>`, `,`, or `;`. - * `pat` and `pat_param` may only be followed by one of: `=>`, `,`, `=`, `|`, `if`, or `in`. + * `pat_param` may only be followed by one of: `=>`, `,`, `=`, `|`, `if`, or `in`. + * `pat` may only be followed by one of: `=>`, `,`, `=`, `if`, or `in`. * `path` and `ty` may only be followed by one of: `=>`, `,`, `=`, `|`, `;`, `:`, `>`, `>>`, `[`, `{`, `as`, `where`, or a macro variable of `block` fragment specifier. @@ -460,6 +465,8 @@ Matchers like `$i:expr,` or `$i:expr;` would be legal, however, because `,` and `ident`, `ty`, or `path` fragment specifier. * All other fragment specifiers have no restrictions. +> **Edition Differences**: Before the 2021 edition, `pat` may also be followed by `|`. + When repetitions are involved, then the rules apply to every possible number of expansions, taking separators into account. This means: @@ -490,6 +497,7 @@ For more detail, see the [formal specification]. [_Item_]: items.md [_LiteralExpression_]: expressions/literal-expr.md [_MetaListIdents_]: attributes.md#meta-item-attribute-syntax +[_Pattern_]: patterns.md [_PatternNoTopAlt_]: patterns.md [_Statement_]: statements.md [_TokenTree_]: macros.md#macro-invocation From 94a041ff3680f90c3b032e84944d4ec33dbd1217 Mon Sep 17 00:00:00 2001 From: Matthew Woodcraft Date: Tue, 11 Jan 2022 22:12:44 +0000 Subject: [PATCH 2/2] Clarify that the macro_rules! `pat` behaviour depends on the macro definition's edition --- src/macros-by-example.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/macros-by-example.md b/src/macros-by-example.md index 4bdab6b03..f7e0ed4dd 100644 --- a/src/macros-by-example.md +++ b/src/macros-by-example.md @@ -143,6 +143,8 @@ transcribed more than once or not at all. > **Edition Differences**: Starting with the 2021 edition, `pat` fragment-specifiers match top-level or-patterns (that is, they accept [_Pattern_]). > > Before the 2021 edition, they match exactly the same fragments as `pat_param` (that is, they accept [_PatternNoTopAlt_]). +> +> The relevant edition is the one in effect for the `macro_rules!` definition. ## Repetitions