Skip to content

Commit

Permalink
Add Lifetime Capture Rules 2024
Browse files Browse the repository at this point in the history
The rules for which generic lifetime parameters are automatically
captured in an RPIT-like opaque type are changing in Rust 2024
according to RFC 3498.  Let's document these changes.
  • Loading branch information
traviscross authored and ehuss committed Nov 25, 2024
1 parent 4ad2685 commit 3a8bef7
Showing 1 changed file with 3 additions and 6 deletions.
9 changes: 3 additions & 6 deletions src/types/impl-trait.md
Original file line number Diff line number Diff line change
Expand Up @@ -119,13 +119,10 @@ Behind each return-position `impl Trait` abstract type is some hidden concrete t
r[type.impl-trait.generic-capture.auto]

r[type.impl-trait.generic-capture.auto.intro]
Return-position `impl Trait` abstract types automatically capture certain of the in-scope generic parameters. Everywhere, these automatically capture all in-scope type and const generic parameters.
Return-position `impl Trait` abstract types automatically capture all in-scope generic parameters, including generic type, const, and lifetime parameters (including higher-ranked ones).

r[type.impl-trait.generic-capture.auto.trait]
On items of trait impls and trait definitions, these types additionally automatically capture all in-scope generic lifetime parameters, including higher-ranked ones\1

r[type.impl-trait.generic-capture.auto.fn]
On free functions and on associated functions and methods of inherent impls, only the generic lifetime parameters that appear in the bounds of abstract return type are captured.
r[type.impl-trait.generic-capture.edition2024]
> **Edition differences**: Before the 2024 edition, on free functions and on associated functions and methods of inherent impls, generic lifetime parameters that do not appear in the bounds of the abstract return type are not automatically captured.
## Precise capturing

Expand Down

0 comments on commit 3a8bef7

Please sign in to comment.