Skip to content

Commit 1f07c24

Browse files
authored
Merge pull request #326 from ehuss/2024-unprefixed-guarded-string
2024: Add reserved syntax
2 parents ddb36f5 + dceaaca commit 1f07c24

File tree

5 files changed

+71
-3
lines changed

5 files changed

+71
-3
lines changed

book.toml

+1
Original file line numberDiff line numberDiff line change
@@ -80,6 +80,7 @@ search.use-boolean-and = true
8080
"/rust-2018/platform-and-target-support/msvc-toolchain-support.html" = "../../../rustc/platform-support.html"
8181
"/rust-2018/platform-and-target-support/musl-support-for-fully-static-binaries.html" = "../../../rustc/platform-support.html"
8282
"/rust-2018/platform-and-target-support/cdylib-crates-for-c-interoperability.html" = "https://github.com/rust-lang/rfcs/blob/master/text/1510-cdylib.md"
83+
"/rust-2021/reserving-syntax.html" = "reserved-syntax.html"
8384
"/rust-next/index.html" = "../rust-2021/index.html"
8485
"/rust-next/edition-changes.html" = "../rust-2021/index.html"
8586
"/rust-next/dbg-macro.html" = "../../std/macro.dbg.html"

src/SUMMARY.md

+2-1
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,7 @@
3030
- [IntoIterator for arrays](rust-2021/IntoIterator-for-arrays.md)
3131
- [Disjoint capture in closures](rust-2021/disjoint-capture-in-closures.md)
3232
- [Panic macro consistency](rust-2021/panic-macro-consistency.md)
33-
- [Reserving syntax](rust-2021/reserving-syntax.md)
33+
- [Reserved syntax](rust-2021/reserved-syntax.md)
3434
- [Warnings promoted to errors](rust-2021/warnings-promoted-to-error.md)
3535
- [Or patterns in macro-rules](rust-2021/or-patterns-macro-rules.md)
3636
- [C-string literals](rust-2021/c-string-literals.md)
@@ -55,3 +55,4 @@
5555
- [Unsafe `extern` blocks](rust-2024/unsafe-extern.md)
5656
- [Unsafe attributes](rust-2024/unsafe-attributes.md)
5757
- [Rustdoc combined tests](rust-2024/rustdoc-doctests.md)
58+
- [Reserved syntax](rust-2024/reserved-syntax.md)

src/rust-2021/c-string-literals.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -69,4 +69,4 @@ Migration is only necessary for macros which may have been assuming a sequence o
6969
As part of the [syntax reservation] for the 2021 edition, any macro input which may run into this issue should issue a warning from the `rust_2021_prefixes_incompatible_syntax` migration lint.
7070
See that chapter for more detail.
7171

72-
[syntax reservation]: reserving-syntax.md
72+
[syntax reservation]: reserved-syntax.md

src/rust-2021/reserving-syntax.md renamed to src/rust-2021/reserved-syntax.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
# Reserving syntax
1+
# Reserved syntax
22

33
## Summary
44

src/rust-2024/reserved-syntax.md

+66
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
# Reserved syntax
2+
3+
🚧 The 2024 Edition has not yet been released and hence this section is still "under construction".
4+
More information may be found in the tracking issue at <https://github.com/rust-lang/rust/issues/123735>.
5+
6+
## Summary
7+
8+
- Unprefixed guarded strings of the form `#"foo"#` are reserved for future use.
9+
- Two or more `#` characters are reserved for future use.
10+
11+
## Details
12+
13+
[RFC 3593] reserved syntax in the 2024 Edition for guarded string literals that do not have a prefix to make room for possible future language changes. The 2021 Edition [reserved syntax][2021] for guarded strings with a prefix, such as `ident##"foo"##`. The 2024 Edition extends that to also reserve strings without the `ident` prefix.
14+
15+
There are two reserved syntaxes:
16+
17+
- One or more `#` characters immediately followed by a [string literal].
18+
- Two or more `#` characters in a row (not separated by whitespace).
19+
20+
This reservation is done across an edition boundary because of interactions with tokenization and macros. For example, consider this macro:
21+
22+
```rust
23+
macro_rules! demo {
24+
( $a:tt ) => { println!("one token") };
25+
( $a:tt $b:tt $c:tt ) => { println!("three tokens") };
26+
}
27+
28+
demo!("foo");
29+
demo!(r#"foo"#);
30+
demo!(#"foo"#);
31+
demo!(###)
32+
```
33+
34+
Prior to the 2024 Edition, this produces:
35+
36+
```text
37+
one token
38+
one token
39+
three tokens
40+
three tokens
41+
```
42+
43+
Starting in the 2024 Edition, the `#"foo"#` line and the `###` line now generates a compile error because those forms are now reserved.
44+
45+
[2021]: ../rust-2021/reserved-syntax.md
46+
[string literal]: ../../reference/tokens.html#string-literals
47+
[RFC 3593]: https://rust-lang.github.io/rfcs/3593-unprefixed-guarded-strings.html
48+
49+
## Migration
50+
51+
The [`rust_2024_guarded_string_incompatible_syntax`] lint will identify any tokens that match the reserved syntax, and will suggest a modification to insert spaces where necessary to ensure the tokens continue to be parsed separately.
52+
53+
The lint is part of the `rust-2024-compatibility` lint group which is included in the automatic edition migration. In order to migrate your code to be Rust 2024 Edition compatible, run:
54+
55+
```sh
56+
cargo fix --edition
57+
```
58+
59+
Alternatively, you can manually enable the lint to find macro calls where you may need to update the tokens:
60+
61+
```rust
62+
// Add this to the root of your crate to do a manual migration.
63+
#![warn(rust_2024_guarded_string_incompatible_syntax)]
64+
```
65+
66+
[`rust_2024_guarded_string_incompatible_syntax`]: ../../rustc/lints/listing/allowed-by-default.html#rust-2024-guarded-string-incompatible-syntax

0 commit comments

Comments
 (0)