From ea93cb5d9f0461890ecf5f80107400cd37efe7a0 Mon Sep 17 00:00:00 2001 From: David Wood Date: Wed, 13 Mar 2019 17:08:34 +0100 Subject: [PATCH] Do not specify type in generated let bindings. This avoids issues with `impl_trait_in_bindings` as the type from the argument is normally used as the let binding, but `impl Trait` is unstable in binding position. --- src/libsyntax/parse/parser.rs | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index c10226053bfff..f16bdf449ae7e 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -8691,15 +8691,16 @@ impl<'a> Parser<'a> { }), }; - // Construct a `let : = __argN;` statement to insert at the top of the + // Construct a `let = __argN;` statement to insert at the top of the // async closure. let local = P(Local { pat: input.pat.clone(), - ty: Some(P(Ty { - id, - node: input.ty.node.clone(), - span: input.ty.span, - })), + // We explicitly do not specify the type for this statement. When the user's + // argument type is `impl Trait` then this would require the + // `impl_trait_in_bindings` feature to also be present for that same type to + // be valid in this binding. At the time of writing (13 Mar 19), + // `impl_trait_in_bindings` is not stable. + ty: None, init: Some(P(Expr { id, node: ExprKind::Path(None, ast::Path {