Skip to content

Commit

Permalink
Rollup merge of rust-lang#72668 - awoimbee:give-fn-parenthetical-nota…
Browse files Browse the repository at this point in the history
…tion-parentheses, r=estebank

Fix missing parentheses Fn notation error

Fixes  rust-lang#72611
Well, fixes the error output, I think E0658 is the right error to throw in this case so I didn't change that
  • Loading branch information
RalfJung authored May 30, 2020
2 parents ffe3292 + c54d4fe commit 65a02f1
Show file tree
Hide file tree
Showing 4 changed files with 77 additions and 2 deletions.
11 changes: 9 additions & 2 deletions src/librustc_typeck/astconv.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1151,9 +1151,16 @@ impl<'o, 'tcx> dyn AstConv<'tcx> + 'o {
.as_ref()
.and_then(|args| args.args.get(0))
.and_then(|arg| match arg {
hir::GenericArg::Type(ty) => {
sess.source_map().span_to_snippet(ty.span).ok()
hir::GenericArg::Type(ty) => match ty.kind {
hir::TyKind::Tup(t) => t
.iter()
.map(|e| sess.source_map().span_to_snippet(e.span))
.collect::<Result<Vec<_>, _>>()
.map(|a| a.join(", ")),
_ => sess.source_map().span_to_snippet(ty.span),
}
.map(|s| format!("({})", s))
.ok(),
_ => None,
})
.unwrap_or_else(|| "()".to_string()),
Expand Down
19 changes: 19 additions & 0 deletions src/test/ui/suggestions/fn-trait-notation.fixed
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// run-rustfix
fn e0658<F, G, H>(f: F, g: G, h: H) -> i32
where
F: Fn(i32) -> i32, //~ ERROR E0658
G: Fn(i32, i32) -> (i32, i32), //~ ERROR E0658
H: Fn(i32) -> i32, //~ ERROR E0658
{
f(3);
g(3, 4);
h(3)
}

fn main() {
e0658(
|a| a,
|a, b| (b, a),
|a| a,
);
}
19 changes: 19 additions & 0 deletions src/test/ui/suggestions/fn-trait-notation.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// run-rustfix
fn e0658<F, G, H>(f: F, g: G, h: H) -> i32
where
F: Fn<i32, Output = i32>, //~ ERROR E0658
G: Fn<(i32, i32, ), Output = (i32, i32)>, //~ ERROR E0658
H: Fn<(i32,), Output = i32>, //~ ERROR E0658
{
f(3);
g(3, 4);
h(3)
}

fn main() {
e0658(
|a| a,
|a, b| (b, a),
|a| a,
);
}
30 changes: 30 additions & 0 deletions src/test/ui/suggestions/fn-trait-notation.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
error[E0658]: the precise format of `Fn`-family traits' type parameters is subject to change
--> $DIR/fn-trait-notation.rs:4:8
|
LL | F: Fn<i32, Output = i32>,
| ^^^^^^^^^^^^^^^^^^^^^ help: use parenthetical notation instead: `Fn(i32) -> i32`
|
= note: see issue #29625 <https://github.com/rust-lang/rust/issues/29625> for more information
= help: add `#![feature(unboxed_closures)]` to the crate attributes to enable

error[E0658]: the precise format of `Fn`-family traits' type parameters is subject to change
--> $DIR/fn-trait-notation.rs:5:8
|
LL | G: Fn<(i32, i32, ), Output = (i32, i32)>,
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use parenthetical notation instead: `Fn(i32, i32) -> (i32, i32)`
|
= note: see issue #29625 <https://github.com/rust-lang/rust/issues/29625> for more information
= help: add `#![feature(unboxed_closures)]` to the crate attributes to enable

error[E0658]: the precise format of `Fn`-family traits' type parameters is subject to change
--> $DIR/fn-trait-notation.rs:6:8
|
LL | H: Fn<(i32,), Output = i32>,
| ^^^^^^^^^^^^^^^^^^^^^^^^ help: use parenthetical notation instead: `Fn(i32) -> i32`
|
= note: see issue #29625 <https://github.com/rust-lang/rust/issues/29625> for more information
= help: add `#![feature(unboxed_closures)]` to the crate attributes to enable

error: aborting due to 3 previous errors

For more information about this error, try `rustc --explain E0658`.

0 comments on commit 65a02f1

Please sign in to comment.