From 6d45b502fa1f039c1ae919e7dec138f39e5e47f1 Mon Sep 17 00:00:00 2001 From: Eric Huss Date: Tue, 14 May 2024 14:12:18 -0700 Subject: [PATCH 1/2] 2024: Document reserving `gen` keyword --- src/SUMMARY.md | 1 + src/rust-2024/gen-keyword.md | 60 ++++++++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 src/rust-2024/gen-keyword.md diff --git a/src/SUMMARY.md b/src/SUMMARY.md index 33c3ac51..f5a9b1a1 100644 --- a/src/SUMMARY.md +++ b/src/SUMMARY.md @@ -47,3 +47,4 @@ - [Cargo: Table and key name consistency](rust-2024/cargo-table-key-names.md) - [Cargo: Reject unused inherited default-features](rust-2024/cargo-inherited-default-features.md) - [Rustfmt: Combine all delimited exprs as last argument](rust-2024/rustfmt-overflow-delimited-expr.md) + - [`gen` keyword](rust-2024/gen-keyword.md) diff --git a/src/rust-2024/gen-keyword.md b/src/rust-2024/gen-keyword.md new file mode 100644 index 00000000..73b2608b --- /dev/null +++ b/src/rust-2024/gen-keyword.md @@ -0,0 +1,60 @@ +# `gen` keyword + +🚧 The 2024 Edition has not yet been released and hence this section is still "under construction". +More information may be found in the tracking issue at . + +## Summary + +- `gen` is a [reserved keyword]. + +[reserved keyword]: ../../reference/keywords.html#reserved-keywords + +## Details + +The `gen` keyword has been reserved as part of [RFC #3513] to introduce "gen blocks" in a future release of Rust. `gen` blocks will provide a way to make it easier to write certain kinds of iterators. Reserving the keyword now will make it easier to stabilize `gen` blocks before the next edition. + +[RFC #3513]: https://rust-lang.github.io/rfcs/3513-gen-blocks.html + +## Migration + +Introducing the `gen` keyword can cause a problem for any identifiers that are already called `gen`. For example, any variable or function name called `gen` would clash with the new keyword. To work around this issue, Rust supports the `r#` prefix for a [raw identifier], which allows identifiers to overlap with keywords. + +The [`keyword_idents_2024`] lint will automatically modify any identifier named `gen` to be `r#gen` so that the code continues to work on both editions. This lint is part of the `rust-2024-compatibility` lint group, which will automatically be applied when running `cargo fix --edition`. To migrate your code to be Rust 2024 Edition compatible, run: + +```sh +cargo fix --edition +``` + +For example, this will change: + +```rust +fn gen() { + println!("generating!"); +} + +fn main() { + gen(); +} +``` + +to be: + +```rust +fn r#gen() { + println!("generating!"); +} + +fn main() { + r#gen(); +} +``` + +Alternatively, you can manually enable the lint to find places where the `gen` identifiers need to be modified to be `r#gen`: + +```rust +// Add this to the root of your crate to do a manual migration. +#![warn(keyword_idents_2024)] +``` + +[raw identifier]: ../../reference/identifiers.html#raw-identifiers +[`keyword_idents_2024`]: ../../rustc/lints/listing/allowed-by-default.html#keyword-idents-2024 From 3d84e10204f98e50f53ef3c68899ea3f90e11359 Mon Sep 17 00:00:00 2001 From: Travis Cross Date: Fri, 24 May 2024 19:02:25 +0000 Subject: [PATCH 2/2] Do some light copyediting --- src/rust-2024/gen-keyword.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/rust-2024/gen-keyword.md b/src/rust-2024/gen-keyword.md index 73b2608b..8881b18b 100644 --- a/src/rust-2024/gen-keyword.md +++ b/src/rust-2024/gen-keyword.md @@ -17,9 +17,9 @@ The `gen` keyword has been reserved as part of [RFC #3513] to introduce "gen blo ## Migration -Introducing the `gen` keyword can cause a problem for any identifiers that are already called `gen`. For example, any variable or function name called `gen` would clash with the new keyword. To work around this issue, Rust supports the `r#` prefix for a [raw identifier], which allows identifiers to overlap with keywords. +Introducing the `gen` keyword can cause a problem for any identifiers that are already called `gen`. For example, any variable or function name called `gen` would clash with the new keyword. To overcome this, Rust supports the `r#` prefix for a [raw identifier], which allows identifiers to overlap with keywords. -The [`keyword_idents_2024`] lint will automatically modify any identifier named `gen` to be `r#gen` so that the code continues to work on both editions. This lint is part of the `rust-2024-compatibility` lint group, which will automatically be applied when running `cargo fix --edition`. To migrate your code to be Rust 2024 Edition compatible, run: +The [`keyword_idents_2024`] lint will automatically modify any identifier named `gen` to be `r#gen` so that code continues to work on both editions. This lint is part of the `rust-2024-compatibility` lint group, which will automatically be applied when running `cargo fix --edition`. To migrate your code to be Rust 2024 Edition compatible, run: ```sh cargo fix --edition @@ -49,7 +49,7 @@ fn main() { } ``` -Alternatively, you can manually enable the lint to find places where the `gen` identifiers need to be modified to be `r#gen`: +Alternatively, you can manually enable the lint to find places where `gen` identifiers need to be modified to `r#gen`: ```rust // Add this to the root of your crate to do a manual migration.