mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-25 16:24:46 +00:00
Rollup merge of #88733 - Noble-Mushtak:88577, r=estebank
Fix ICE for functions with more than 65535 arguments This pull request fixes #88577 by changing the `param_idx` field in the `Param` variant of `WellFormedLoc` from `u16` to `u32`, thus allowing for more than 65,535 arguments in a function. Note that I also added a regression test, but needed to add `// ignore-tidy-filelength` because the test is more than 8000 lines long.
This commit is contained in:
commit
746eb1d84d
@ -422,11 +422,25 @@ impl<'a> AstValidator<'a> {
|
||||
}
|
||||
|
||||
fn check_fn_decl(&self, fn_decl: &FnDecl, self_semantic: SelfSemantic) {
|
||||
self.check_decl_num_args(fn_decl);
|
||||
self.check_decl_cvaradic_pos(fn_decl);
|
||||
self.check_decl_attrs(fn_decl);
|
||||
self.check_decl_self_param(fn_decl, self_semantic);
|
||||
}
|
||||
|
||||
/// Emits fatal error if function declaration has more than `u16::MAX` arguments
|
||||
/// Error is fatal to prevent errors during typechecking
|
||||
fn check_decl_num_args(&self, fn_decl: &FnDecl) {
|
||||
let max_num_args: usize = u16::MAX.into();
|
||||
if fn_decl.inputs.len() > max_num_args {
|
||||
let Param { span, .. } = fn_decl.inputs[0];
|
||||
self.err_handler().span_fatal(
|
||||
span,
|
||||
&format!("function can not have more than {} arguments", max_num_args),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
fn check_decl_cvaradic_pos(&self, fn_decl: &FnDecl) {
|
||||
match &*fn_decl.inputs {
|
||||
[Param { ty, span, .. }] => {
|
||||
|
@ -0,0 +1,12 @@
|
||||
macro_rules! many_args {
|
||||
([$($t:tt)*]#$($h:tt)*) => {
|
||||
many_args!{[$($t)*$($t)*]$($h)*}
|
||||
};
|
||||
([$($t:tt)*]) => {
|
||||
fn _f($($t: ()),*) {} //~ ERROR function can not have more than 65535 arguments
|
||||
}
|
||||
}
|
||||
|
||||
many_args!{[_]########## ######}
|
||||
|
||||
fn main() {}
|
@ -0,0 +1,13 @@
|
||||
error: function can not have more than 65535 arguments
|
||||
--> $DIR/issue-88577-check-fn-with-more-than-65535-arguments.rs:6:24
|
||||
|
|
||||
LL | fn _f($($t: ()),*) {}
|
||||
| ________________________^
|
||||
LL | | }
|
||||
LL | | }
|
||||
LL | |
|
||||
LL | | many_args!{[_]########## ######}
|
||||
| |____________^
|
||||
|
||||
error: aborting due to previous error
|
||||
|
Loading…
Reference in New Issue
Block a user