diff options
| author | Michael Goulet <michael@errs.io> | 2023-03-16 04:02:56 +0000 | 
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2023-03-16 04:02:56 +0000 | 
| commit | 60da5de1c68e8465f4896f8cd5a8b158c00051a1 (patch) | |
| tree | 4e9e96d730c7db15556dd364126617f39bafab31 | |
| parent | c90eb4825a9faca0d6317292a452859f00d5b786 (diff) | |
| download | rust-60da5de1c68e8465f4896f8cd5a8b158c00051a1.tar.gz rust-60da5de1c68e8465f4896f8cd5a8b158c00051a1.zip | |
Fix index out of bounds in suggest_trait_fn_ty_for_impl_fn_infer
| -rw-r--r-- | compiler/rustc_hir_analysis/src/astconv/mod.rs | 9 | ||||
| -rw-r--r-- | tests/ui/suggestions/bad-infer-in-trait-impl.rs | 10 | ||||
| -rw-r--r-- | tests/ui/suggestions/bad-infer-in-trait-impl.stderr | 14 | 
3 files changed, 30 insertions, 3 deletions
| diff --git a/compiler/rustc_hir_analysis/src/astconv/mod.rs b/compiler/rustc_hir_analysis/src/astconv/mod.rs index f830269b45d..3c2cf0d80ab 100644 --- a/compiler/rustc_hir_analysis/src/astconv/mod.rs +++ b/compiler/rustc_hir_analysis/src/astconv/mod.rs @@ -3317,10 +3317,13 @@ impl<'o, 'tcx> dyn AstConv<'tcx> + 'o { tcx, trait_ref.substs.extend_to(tcx, assoc.def_id, |param, _| tcx.mk_param_from_def(param)), ); + let fn_sig = tcx.liberate_late_bound_regions(fn_hir_id.expect_owner().to_def_id(), fn_sig); - let ty = if let Some(arg_idx) = arg_idx { fn_sig.input(arg_idx) } else { fn_sig.output() }; - - Some(tcx.liberate_late_bound_regions(fn_hir_id.expect_owner().to_def_id(), ty)) + Some(if let Some(arg_idx) = arg_idx { + *fn_sig.inputs().get(arg_idx)? + } else { + fn_sig.output() + }) } #[instrument(level = "trace", skip(self, generate_err))] diff --git a/tests/ui/suggestions/bad-infer-in-trait-impl.rs b/tests/ui/suggestions/bad-infer-in-trait-impl.rs new file mode 100644 index 00000000000..87db2636fb2 --- /dev/null +++ b/tests/ui/suggestions/bad-infer-in-trait-impl.rs @@ -0,0 +1,10 @@ +trait Foo { + fn bar(); +} + +impl Foo for () { + fn bar(s: _) {} + //~^ ERROR the placeholder `_` is not allowed within types on item signatures for functions +} + +fn main() {} diff --git a/tests/ui/suggestions/bad-infer-in-trait-impl.stderr b/tests/ui/suggestions/bad-infer-in-trait-impl.stderr new file mode 100644 index 00000000000..418690ff85f --- /dev/null +++ b/tests/ui/suggestions/bad-infer-in-trait-impl.stderr @@ -0,0 +1,14 @@ +error[E0121]: the placeholder `_` is not allowed within types on item signatures for functions + --> $DIR/bad-infer-in-trait-impl.rs:6:15 + | +LL | fn bar(s: _) {} + | ^ not allowed in type signatures + | +help: use type parameters instead + | +LL | fn bar<T>(s: T) {} + | +++ ~ + +error: aborting due to previous error + +For more information about this error, try `rustc --explain E0121`. | 
