mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-10 06:47:34 +00:00
Merge pull request #817 from mcarton/eta
Fix FP in `REDUNDANT_CLOSURE` with divergent functions
This commit is contained in:
commit
4f17633653
@ -61,7 +61,8 @@ fn check_closure(cx: &LateContext, expr: &Expr) {
|
|||||||
match fn_ty.sty {
|
match fn_ty.sty {
|
||||||
// Is it an unsafe function? They don't implement the closure traits
|
// Is it an unsafe function? They don't implement the closure traits
|
||||||
ty::TyFnDef(_, _, fn_ty) | ty::TyFnPtr(fn_ty) => {
|
ty::TyFnDef(_, _, fn_ty) | ty::TyFnPtr(fn_ty) => {
|
||||||
if fn_ty.unsafety == Unsafety::Unsafe {
|
if fn_ty.unsafety == Unsafety::Unsafe ||
|
||||||
|
fn_ty.sig.skip_binder().output == ty::FnOutput::FnDiverging {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,14 @@ fn main() {
|
|||||||
Some(1u8).map(|a| unsafe_fn(a)); // unsafe fn
|
Some(1u8).map(|a| unsafe_fn(a)); // unsafe fn
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// See #815
|
||||||
|
let e = Some(1u8).map(|a| divergent(a));
|
||||||
|
let e = Some(1u8).map(|a| generic(a));
|
||||||
|
//~^ ERROR redundant closure found
|
||||||
|
//~| HELP remove closure as shown
|
||||||
|
//~| SUGGESTION map(generic);
|
||||||
|
let e = Some(1u8).map(generic);
|
||||||
|
|
||||||
// See #515
|
// See #515
|
||||||
let a: Option<Box<::std::ops::Deref<Target = [i32]>>> =
|
let a: Option<Box<::std::ops::Deref<Target = [i32]>>> =
|
||||||
Some(vec![1i32, 2]).map(|v| -> Box<::std::ops::Deref<Target = [i32]>> { Box::new(v) });
|
Some(vec![1i32, 2]).map(|v| -> Box<::std::ops::Deref<Target = [i32]>> { Box::new(v) });
|
||||||
@ -47,3 +55,11 @@ where F: Fn(&X, &X) -> bool {
|
|||||||
fn below(x: &u8, y: &u8) -> bool { x < y }
|
fn below(x: &u8, y: &u8) -> bool { x < y }
|
||||||
|
|
||||||
unsafe fn unsafe_fn(_: u8) { }
|
unsafe fn unsafe_fn(_: u8) { }
|
||||||
|
|
||||||
|
fn divergent(_: u8) -> ! {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn generic<T>(_: T) -> u8 {
|
||||||
|
0
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user