Remove unnecessary CVarArgs name skipping logic

This commit is contained in:
DaniPopes 2023-10-25 17:44:17 +02:00
parent 2c1dbed4aa
commit 6aead74ff2
No known key found for this signature in database
GPG Key ID: 0F09640DDB7AC692
2 changed files with 2 additions and 9 deletions

View File

@ -1737,14 +1737,7 @@ impl<'a, 'hir> LoweringContext<'a, 'hir> {
}
fn lower_fn_params_to_names(&mut self, decl: &FnDecl) -> &'hir [Ident] {
// Skip the `...` (`CVarArgs`) trailing arguments from the AST,
// as they are not explicit in HIR/Ty function signatures.
// (instead, the `c_variadic` flag is set to `true`)
let mut inputs = &decl.inputs[..];
if decl.c_variadic() {
inputs = &inputs[..inputs.len() - 1];
}
self.arena.alloc_from_iter(inputs.iter().map(|param| match param.pat.kind {
self.arena.alloc_from_iter(decl.inputs.iter().map(|param| match param.pat.kind {
PatKind::Ident(_, ident, _) => self.lower_ident(ident),
_ => Ident::new(kw::Empty, self.lower_span(param.pat.span)),
}))

View File

@ -9,7 +9,7 @@ use ::std::prelude::rust_2015::*;
extern crate std;
extern "C" {
fn foo(x: i32, ...);
fn foo(x: i32, va1: ...);
}
unsafe extern "C" fn bar(_: i32, mut va2: ...) -> usize { va2.arg::<usize>() }