mirror of
https://github.com/rust-lang/rust-clippy
synced 2025-01-02 08:19:11 +00:00
37 lines
1.4 KiB
Rust
37 lines
1.4 KiB
Rust
use clippy_utils::diagnostics::span_lint_and_sugg;
|
|
use clippy_utils::source::snippet_with_applicability;
|
|
use rustc_errors::Applicability;
|
|
use rustc_hir::Expr;
|
|
use rustc_lint::LateContext;
|
|
use rustc_middle::ty::{self, Ty, UintTy};
|
|
|
|
use super::{utils, FN_TO_NUMERIC_CAST};
|
|
|
|
pub(super) fn check(cx: &LateContext<'_>, expr: &Expr<'_>, cast_expr: &Expr<'_>, cast_from: Ty<'_>, cast_to: Ty<'_>) {
|
|
// We only want to check casts to `ty::Uint` or `ty::Int`
|
|
match cast_to.kind() {
|
|
ty::Uint(_) | ty::Int(..) => { /* continue on */ },
|
|
_ => return,
|
|
}
|
|
|
|
match cast_from.kind() {
|
|
ty::FnDef(..) | ty::FnPtr(_) => {
|
|
let mut applicability = Applicability::MaybeIncorrect;
|
|
let from_snippet = snippet_with_applicability(cx, cast_expr.span, "x", &mut applicability);
|
|
let to_nbits = utils::int_ty_to_nbits(cast_to, cx.tcx);
|
|
|
|
if (to_nbits >= cx.tcx.data_layout.pointer_size.bits()) && (*cast_to.kind() != ty::Uint(UintTy::Usize)) {
|
|
span_lint_and_sugg(
|
|
cx,
|
|
FN_TO_NUMERIC_CAST,
|
|
expr.span,
|
|
&format!("casting function pointer `{}` to `{}`", from_snippet, cast_to),
|
|
"try",
|
|
format!("{} as usize", from_snippet),
|
|
applicability,
|
|
);
|
|
}
|
|
},
|
|
_ => {},
|
|
}
|
|
}
|