Skip to content

Commit

Permalink
Rollup merge of rust-lang#60052 - varkor:unused-parameter-diagnostic,…
Browse files Browse the repository at this point in the history
… r=estebank

Correct unused parameter diagnostic

The message was incorrect for unused lifetime parameters. There's no need to be specific.
  • Loading branch information
Centril authored Apr 19, 2019
2 parents bd0d097 + 048ba28 commit 2d6150a
Show file tree
Hide file tree
Showing 14 changed files with 27 additions and 24 deletions.
13 changes: 8 additions & 5 deletions src/librustc_typeck/check/wfcheck.rs
Original file line number Diff line number Diff line change
Expand Up @@ -938,17 +938,20 @@ fn check_variances_for_type_defn<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
.map(|(index, _)| Parameter(index as u32))
.collect();

identify_constrained_generic_params(tcx,
&ty_predicates,
None,
&mut constrained_parameters);
identify_constrained_generic_params(
tcx,
&ty_predicates,
None,
&mut constrained_parameters,
);

for (index, _) in variances.iter().enumerate() {
if constrained_parameters.contains(&Parameter(index as u32)) {
continue;
}

let param = &hir_generics.params[index];

match param.name {
hir::ParamName::Error => { }
_ => report_bivariance(tcx, param.span, param.name.ident().name),
Expand Down Expand Up @@ -1123,7 +1126,7 @@ fn error_392<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, span: Span, param_name: ast:
-> DiagnosticBuilder<'tcx> {
let mut err = struct_span_err!(tcx.sess, span, E0392,
"parameter `{}` is never used", param_name);
err.span_label(span, "unused type parameter");
err.span_label(span, "unused parameter");
err
}

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/error-codes/E0392.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ error[E0392]: parameter `T` is never used
--> $DIR/E0392.rs:1:10
|
LL | enum Foo<T> { Bar }
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `T` or using a marker such as `std::marker::PhantomData`

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/inner-static-type-parameter.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ error[E0392]: parameter `T` is never used
--> $DIR/inner-static-type-parameter.rs:3:10
|
LL | enum Bar<T> { What }
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `T` or using a marker such as `std::marker::PhantomData`

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/issues/issue-17904-2.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ error[E0392]: parameter `T` is never used
--> $DIR/issue-17904-2.rs:4:12
|
LL | struct Foo<T> where T: Copy;
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `T` or using a marker such as `std::marker::PhantomData`

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/issues/issue-20413.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ error[E0392]: parameter `T` is never used
--> $DIR/issue-20413.rs:5:15
|
LL | struct NoData<T>;
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `T` or using a marker such as `std::marker::PhantomData`

Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/issues/issue-36299.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@ error[E0392]: parameter `'a` is never used
--> $DIR/issue-36299.rs:1:12
|
LL | struct Foo<'a, A> {}
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'a` or using a marker such as `std::marker::PhantomData`

error[E0392]: parameter `A` is never used
--> $DIR/issue-36299.rs:1:16
|
LL | struct Foo<'a, A> {}
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `A` or using a marker such as `std::marker::PhantomData`

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/issues/issue-36638.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ error[E0392]: parameter `Self` is never used
--> $DIR/issue-36638.rs:3:12
|
LL | struct Foo<Self>(Self);
| ^^^^ unused type parameter
| ^^^^ unused parameter
|
= help: consider removing `Self` or using a marker such as `std::marker::PhantomData`

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/issues/issue-37534.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ error[E0392]: parameter `T` is never used
--> $DIR/issue-37534.rs:1:12
|
LL | struct Foo<T: ?Hash> { }
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `T` or using a marker such as `std::marker::PhantomData`

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ error[E0392]: parameter `'c` is never used
--> $DIR/region-bounds-on-objects-and-type-parameters.rs:11:18
|
LL | struct Foo<'a,'b,'c> {
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'c` or using a marker such as `std::marker::PhantomData`

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/self/self_type_keyword.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ error[E0392]: parameter `'Self` is never used
--> $DIR/self_type_keyword.rs:8:12
|
LL | struct Bar<'Self>;
| ^^^^^ unused type parameter
| ^^^^^ unused parameter
|
= help: consider removing `'Self` or using a marker such as `std::marker::PhantomData`

Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/variance/variance-regions-unused-direct.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@ error[E0392]: parameter `'a` is never used
--> $DIR/variance-regions-unused-direct.rs:5:18
|
LL | struct Bivariant<'a>;
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'a` or using a marker such as `std::marker::PhantomData`

error[E0392]: parameter `'d` is never used
--> $DIR/variance-regions-unused-direct.rs:7:19
|
LL | struct Struct<'a, 'd> {
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'d` or using a marker such as `std::marker::PhantomData`

Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/variance/variance-regions-unused-indirect.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@ error[E0392]: parameter `'a` is never used
--> $DIR/variance-regions-unused-indirect.rs:3:10
|
LL | enum Foo<'a> {
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'a` or using a marker such as `std::marker::PhantomData`

error[E0392]: parameter `'a` is never used
--> $DIR/variance-regions-unused-indirect.rs:7:10
|
LL | enum Bar<'a> {
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'a` or using a marker such as `std::marker::PhantomData`

Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/variance/variance-unused-region-param.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@ error[E0392]: parameter `'a` is never used
--> $DIR/variance-unused-region-param.rs:3:19
|
LL | struct SomeStruct<'a> { x: u32 }
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'a` or using a marker such as `std::marker::PhantomData`

error[E0392]: parameter `'a` is never used
--> $DIR/variance-unused-region-param.rs:4:15
|
LL | enum SomeEnum<'a> { Nothing }
| ^^ unused type parameter
| ^^ unused parameter
|
= help: consider removing `'a` or using a marker such as `std::marker::PhantomData`

Expand Down
6 changes: 3 additions & 3 deletions src/test/ui/variance/variance-unused-type-param.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,23 +2,23 @@ error[E0392]: parameter `A` is never used
--> $DIR/variance-unused-type-param.rs:6:19
|
LL | struct SomeStruct<A> { x: u32 }
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `A` or using a marker such as `std::marker::PhantomData`

error[E0392]: parameter `A` is never used
--> $DIR/variance-unused-type-param.rs:9:15
|
LL | enum SomeEnum<A> { Nothing }
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `A` or using a marker such as `std::marker::PhantomData`

error[E0392]: parameter `T` is never used
--> $DIR/variance-unused-type-param.rs:13:15
|
LL | enum ListCell<T> {
| ^ unused type parameter
| ^ unused parameter
|
= help: consider removing `T` or using a marker such as `std::marker::PhantomData`

Expand Down

0 comments on commit 2d6150a

Please sign in to comment.