diff options
| author | Mara Bos <m-ou.se@m-ou.se> | 2025-08-26 14:44:41 +0200 |
|---|---|---|
| committer | Mara Bos <m-ou.se@m-ou.se> | 2025-08-26 14:46:11 +0200 |
| commit | aa9c8ceb73c88674a792719dee8bfbcbee22a360 (patch) | |
| tree | f14c5d3c1a91e86a8fe4844254dddaa74ae1b098 | |
| parent | 5fb947f650ef123ab91bb3456161f50f481adf9b (diff) | |
| download | rust-aa9c8ceb73c88674a792719dee8bfbcbee22a360.tar.gz rust-aa9c8ceb73c88674a792719dee8bfbcbee22a360.zip | |
Remove 1-argument special case from format_args!().
The argument needs to be lifetime-extended, so this special case isn't actually perfectly equivalent to the general case.
| -rw-r--r-- | compiler/rustc_ast_lowering/src/format.rs | 20 |
1 files changed, 0 insertions, 20 deletions
diff --git a/compiler/rustc_ast_lowering/src/format.rs b/compiler/rustc_ast_lowering/src/format.rs index ec9d26eb33f..2871430030c 100644 --- a/compiler/rustc_ast_lowering/src/format.rs +++ b/compiler/rustc_ast_lowering/src/format.rs @@ -487,26 +487,6 @@ fn expand_format_args<'hir>( // Generate: // [] (vec![], ctx.arena.alloc(ctx.expr(macsp, hir::ExprKind::Array(&[])))) - } else if argmap.len() == 1 && arguments.len() == 1 { - // Only one argument, so we don't need to make the `args` tuple. - // - // Generate: - // super let args = [<core::fmt::Argument>::new_display(&arg)]; - let args = ctx.arena.alloc_from_iter(argmap.iter().map( - |(&(arg_index, ty), &placeholder_span)| { - let arg = &arguments[arg_index]; - let placeholder_span = - placeholder_span.unwrap_or(arg.expr.span).with_ctxt(macsp.ctxt()); - let arg = ctx.lower_expr(&arg.expr); - let ref_arg = ctx.arena.alloc(ctx.expr_ref(arg.span.with_ctxt(macsp.ctxt()), arg)); - make_argument(ctx, placeholder_span, ref_arg, ty) - }, - )); - let args = ctx.arena.alloc(ctx.expr(macsp, hir::ExprKind::Array(args))); - let args_ident = Ident::new(sym::args, macsp); - let (args_pat, args_hir_id) = ctx.pat_ident(macsp, args_ident); - let let_statement = ctx.stmt_super_let_pat(macsp, args_pat, Some(args)); - (vec![let_statement], ctx.arena.alloc(ctx.expr_ident_mut(macsp, args_ident, args_hir_id))) } else { // Generate: // super let args = (&arg0, &arg1, &…); |
