extract common codes
Signed-off-by: TennyZhuang <zty0826@gmail.com>
This commit is contained in:
parent
f2043989ca
commit
bff811bfdf
@ -34,7 +34,7 @@ pub(super) fn check<'tcx>(
|
|||||||
let cast_str = snippet_opt(cx, cast_expr.span).unwrap_or_default();
|
let cast_str = snippet_opt(cx, cast_expr.span).unwrap_or_default();
|
||||||
|
|
||||||
if let Some(lit) = get_numeric_literal(cast_expr) {
|
if let Some(lit) = get_numeric_literal(cast_expr) {
|
||||||
let literal_str = cast_str;
|
let literal_str = &cast_str;
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let LitKind::Int(n, _) = lit.node;
|
if let LitKind::Int(n, _) = lit.node;
|
||||||
@ -52,10 +52,12 @@ pub(super) fn check<'tcx>(
|
|||||||
|
|
||||||
match lit.node {
|
match lit.node {
|
||||||
LitKind::Int(_, LitIntType::Unsuffixed) if cast_to.is_integral() => {
|
LitKind::Int(_, LitIntType::Unsuffixed) if cast_to.is_integral() => {
|
||||||
lint_unnecessary_cast(cx, expr, &literal_str, cast_from, cast_to);
|
lint_unnecessary_cast(cx, expr, literal_str, cast_from, cast_to);
|
||||||
|
return true;
|
||||||
},
|
},
|
||||||
LitKind::Float(_, LitFloatType::Unsuffixed) if cast_to.is_floating_point() => {
|
LitKind::Float(_, LitFloatType::Unsuffixed) if cast_to.is_floating_point() => {
|
||||||
lint_unnecessary_cast(cx, expr, &literal_str, cast_from, cast_to);
|
lint_unnecessary_cast(cx, expr, literal_str, cast_from, cast_to);
|
||||||
|
return true;
|
||||||
},
|
},
|
||||||
LitKind::Int(_, LitIntType::Unsuffixed) | LitKind::Float(_, LitFloatType::Unsuffixed) => {},
|
LitKind::Int(_, LitIntType::Unsuffixed) | LitKind::Float(_, LitFloatType::Unsuffixed) => {},
|
||||||
LitKind::Int(_, LitIntType::Signed(_) | LitIntType::Unsigned(_))
|
LitKind::Int(_, LitIntType::Signed(_) | LitIntType::Unsigned(_))
|
||||||
@ -65,25 +67,15 @@ pub(super) fn check<'tcx>(
|
|||||||
if let Some(src) = snippet_opt(cx, cast_expr.span) {
|
if let Some(src) = snippet_opt(cx, cast_expr.span) {
|
||||||
if let Some(num_lit) = NumericLiteral::from_lit_kind(&src, &lit.node) {
|
if let Some(num_lit) = NumericLiteral::from_lit_kind(&src, &lit.node) {
|
||||||
lint_unnecessary_cast(cx, expr, num_lit.integer, cast_from, cast_to);
|
lint_unnecessary_cast(cx, expr, num_lit.integer, cast_from, cast_to);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
_ => {
|
_ => {},
|
||||||
if cast_from.kind() == cast_to.kind() && !in_external_macro(cx.sess(), expr.span) {
|
|
||||||
span_lint_and_sugg(
|
|
||||||
cx,
|
|
||||||
UNNECESSARY_CAST,
|
|
||||||
expr.span,
|
|
||||||
&format!("casting to the same type is unnecessary (`{cast_from}` -> `{cast_to}`)"),
|
|
||||||
"try",
|
|
||||||
literal_str,
|
|
||||||
Applicability::MachineApplicable,
|
|
||||||
);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
} else if cast_from.kind() == cast_to.kind() && !in_external_macro(cx.sess(), expr.span) {
|
}
|
||||||
|
|
||||||
|
if cast_from.kind() == cast_to.kind() && !in_external_macro(cx.sess(), expr.span) {
|
||||||
span_lint_and_sugg(
|
span_lint_and_sugg(
|
||||||
cx,
|
cx,
|
||||||
UNNECESSARY_CAST,
|
UNNECESSARY_CAST,
|
||||||
|
Loading…
Reference in New Issue
Block a user