-
Notifications
You must be signed in to change notification settings - Fork 13.6k
Open
5 / 165 of 16 issues completedLabels
B-experimentalBlocker: In-tree experiment; RFC pending, not yet approved or unneeded (requires FCP to stabilize).Blocker: In-tree experiment; RFC pending, not yet approved or unneeded (requires FCP to stabilize).C-tracking-issueCategory: An issue tracking the progress of sth. like the implementation of an RFCCategory: An issue tracking the progress of sth. like the implementation of an RFCF-explicit_tail_calls`#![feature(explicit_tail_calls)]``#![feature(explicit_tail_calls)]`T-langRelevant to the language teamRelevant to the language team
Description
This is a tracking issue for the RFC "Explicit Tail Calls" (rust-lang/rfcs#3407) (note that RFC is not accepted yet, this feature is currently implemented as part of an experiment).
The feature gate for the issue is #![feature(explicit_tail_calls)]
.
About tracking issues
Tracking issues are used to record the overall progress of implementation.
They are also used as hubs connecting to other relevant issues, e.g., bugs or open design questions.
A tracking issue is however not meant for large scale discussion, questions, or bug reports about a feature.
Instead, open a dedicated issue for the specific matter and add the relevant feature gate label.
Steps
- Implement the RFC
- Adjust documentation (see instructions on rustc-dev-guide)
- Stabilization PR (see instructions on rustc-dev-guide)
Unresolved Questions
(fill when the rfc is merged)
Implementation history
- Syntactically accept
become
expressions (explicit tail calls experiment) #112790 - llvm ffi: Expose
CallInst->setTailCallKind
#112791 -
hir
: AddBecome
expression kind (explicit tail calls experiment) #112887 -
thir
: AddBecome
expression kind #113093 - Document
become
keyword #113095 - Support tail calls in mir via
TerminatorKind::TailCall
#113128 - implement checks for tail calls #133607
- fix tail call checks wrt
#[track_caller]
#135973 - Don't drop types with no drop glue when building drops for tailcalls #135976
- Implement support for
become
and explicit tail call codegen for the LLVM backend #144232 - detect infinite recursion with tail calls in ctfe #144756
- Properly reject tail calls to
&FnPtr
or&FnDef
#144817 - Anonymize binders in tail call sig #144835
- Forbid tail calling intrinsics #144851
- Fix tail calls to
#[track_caller]
functions #144865 - Enforce tail call type is related to body return type in borrowck #144917
- Dont print arg span in MIR dump for tail call #144920
- Allocate arguments from topmost frame into temporary storage before popping stack frame in
init_fn_tail_call
#144933 - Defer tail call ret ty equality to check_tail_calls #144915
schneiderfelipe, leonardo-m, smasher164, xty, DrGo and 13 moreschneiderfelipe, smasher164, yerke, chrilves, rami3l and 3 moreDdystopia, jprochazk, narpfel, TENX-S, KisaragiEffective and 23 moreRobbepop, compiler-errors, saethlin, phi-go, lqd and 12 moreZapeth, schneiderfelipe, smasher164, Mroik and Rudxain
Sub-issues
Metadata
Metadata
Assignees
Labels
B-experimentalBlocker: In-tree experiment; RFC pending, not yet approved or unneeded (requires FCP to stabilize).Blocker: In-tree experiment; RFC pending, not yet approved or unneeded (requires FCP to stabilize).C-tracking-issueCategory: An issue tracking the progress of sth. like the implementation of an RFCCategory: An issue tracking the progress of sth. like the implementation of an RFCF-explicit_tail_calls`#![feature(explicit_tail_calls)]``#![feature(explicit_tail_calls)]`T-langRelevant to the language teamRelevant to the language team