mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-19 03:03:21 +00:00
Remove a span from hir::ExprKind::MethodCall
This commit is contained in:
parent
ec00cf80a3
commit
82f613ee3b
@ -59,7 +59,7 @@ impl<'a, 'tcx> Visitor<'tcx> for ExVisitor<'a, 'tcx> {
|
|||||||
// do not lint if the closure is called using an iterator (see #1141)
|
// do not lint if the closure is called using an iterator (see #1141)
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let Some(parent) = get_parent_expr(self.cx, expr);
|
if let Some(parent) = get_parent_expr(self.cx, expr);
|
||||||
if let ExprKind::MethodCall(_, _, [self_arg, ..], _) = &parent.kind;
|
if let ExprKind::MethodCall(_, [self_arg, ..], _) = &parent.kind;
|
||||||
let caller = self.cx.typeck_results().expr_ty(self_arg);
|
let caller = self.cx.typeck_results().expr_ty(self_arg);
|
||||||
if let Some(iter_id) = self.cx.tcx.get_diagnostic_item(sym::Iterator);
|
if let Some(iter_id) = self.cx.tcx.get_diagnostic_item(sym::Iterator);
|
||||||
if implements_trait(self.cx, caller, iter_id, &[]);
|
if implements_trait(self.cx, caller, iter_id, &[]);
|
||||||
|
@ -259,7 +259,7 @@ fn simplify_not(cx: &LateContext<'_>, expr: &Expr<'_>) -> Option<String> {
|
|||||||
))
|
))
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(path, _, args, _) if args.len() == 1 => {
|
ExprKind::MethodCall(path, args, _) if args.len() == 1 => {
|
||||||
let type_of_receiver = cx.typeck_results().expr_ty(&args[0]);
|
let type_of_receiver = cx.typeck_results().expr_ty(&args[0]);
|
||||||
if !is_type_diagnostic_item(cx, type_of_receiver, sym::Option)
|
if !is_type_diagnostic_item(cx, type_of_receiver, sym::Option)
|
||||||
&& !is_type_diagnostic_item(cx, type_of_receiver, sym::Result)
|
&& !is_type_diagnostic_item(cx, type_of_receiver, sym::Result)
|
||||||
|
@ -41,9 +41,9 @@ declare_lint_pass!(ByteCount => [NAIVE_BYTECOUNT]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for ByteCount {
|
impl<'tcx> LateLintPass<'tcx> for ByteCount {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(count, _, [count_recv], _) = expr.kind;
|
if let ExprKind::MethodCall(count, [count_recv], _) = expr.kind;
|
||||||
if count.ident.name == sym::count;
|
if count.ident.name == sym::count;
|
||||||
if let ExprKind::MethodCall(filter, _, [filter_recv, filter_arg], _) = count_recv.kind;
|
if let ExprKind::MethodCall(filter, [filter_recv, filter_arg], _) = count_recv.kind;
|
||||||
if filter.ident.name == sym!(filter);
|
if filter.ident.name == sym!(filter);
|
||||||
if let ExprKind::Closure(_, _, body_id, _, _) = filter_arg.kind;
|
if let ExprKind::Closure(_, _, body_id, _, _) = filter_arg.kind;
|
||||||
let body = cx.tcx.hir().body(body_id);
|
let body = cx.tcx.hir().body(body_id);
|
||||||
@ -68,7 +68,7 @@ impl<'tcx> LateLintPass<'tcx> for ByteCount {
|
|||||||
if ty::Uint(UintTy::U8) == *cx.typeck_results().expr_ty(needle).peel_refs().kind();
|
if ty::Uint(UintTy::U8) == *cx.typeck_results().expr_ty(needle).peel_refs().kind();
|
||||||
if !is_local_used(cx, needle, arg_id);
|
if !is_local_used(cx, needle, arg_id);
|
||||||
then {
|
then {
|
||||||
let haystack = if let ExprKind::MethodCall(path, _, args, _) =
|
let haystack = if let ExprKind::MethodCall(path, args, _) =
|
||||||
filter_recv.kind {
|
filter_recv.kind {
|
||||||
let p = path.ident.name;
|
let p = path.ident.name;
|
||||||
if (p == sym::iter || p == sym!(iter_mut)) && args.len() == 1 {
|
if (p == sym::iter || p == sym!(iter_mut)) && args.len() == 1 {
|
||||||
|
@ -37,7 +37,7 @@ declare_lint_pass!(CaseSensitiveFileExtensionComparisons => [CASE_SENSITIVE_FILE
|
|||||||
|
|
||||||
fn check_case_sensitive_file_extension_comparison(ctx: &LateContext<'_>, expr: &Expr<'_>) -> Option<Span> {
|
fn check_case_sensitive_file_extension_comparison(ctx: &LateContext<'_>, expr: &Expr<'_>) -> Option<Span> {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(PathSegment { ident, .. }, _, [obj, extension, ..], span) = expr.kind;
|
if let ExprKind::MethodCall(PathSegment { ident, .. }, [obj, extension, ..], span) = expr.kind;
|
||||||
if ident.as_str() == "ends_with";
|
if ident.as_str() == "ends_with";
|
||||||
if let ExprKind::Lit(Spanned { node: LitKind::Str(ext_literal, ..), ..}) = extension.kind;
|
if let ExprKind::Lit(Spanned { node: LitKind::Str(ext_literal, ..), ..}) = extension.kind;
|
||||||
if (2..=6).contains(&ext_literal.as_str().len());
|
if (2..=6).contains(&ext_literal.as_str().len());
|
||||||
|
@ -43,7 +43,7 @@ fn apply_reductions(cx: &LateContext<'_>, nbits: u64, expr: &Expr<'_>, signed: b
|
|||||||
},
|
},
|
||||||
_ => nbits,
|
_ => nbits,
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(method, _, [left, right], _) => {
|
ExprKind::MethodCall(method, [left, right], _) => {
|
||||||
if signed {
|
if signed {
|
||||||
return nbits;
|
return nbits;
|
||||||
}
|
}
|
||||||
@ -54,7 +54,7 @@ fn apply_reductions(cx: &LateContext<'_>, nbits: u64, expr: &Expr<'_>, signed: b
|
|||||||
};
|
};
|
||||||
apply_reductions(cx, nbits, left, signed).min(max_bits.unwrap_or(u64::max_value()))
|
apply_reductions(cx, nbits, left, signed).min(max_bits.unwrap_or(u64::max_value()))
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(method, _, [_, lo, hi], _) => {
|
ExprKind::MethodCall(method, [_, lo, hi], _) => {
|
||||||
if method.ident.as_str() == "clamp" {
|
if method.ident.as_str() == "clamp" {
|
||||||
//FIXME: make this a diagnostic item
|
//FIXME: make this a diagnostic item
|
||||||
if let (Some(lo_bits), Some(hi_bits)) = (get_constant_bits(cx, lo), get_constant_bits(cx, hi)) {
|
if let (Some(lo_bits), Some(hi_bits)) = (get_constant_bits(cx, lo), get_constant_bits(cx, hi)) {
|
||||||
@ -63,7 +63,7 @@ fn apply_reductions(cx: &LateContext<'_>, nbits: u64, expr: &Expr<'_>, signed: b
|
|||||||
}
|
}
|
||||||
nbits
|
nbits
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(method, _, [_value], _) => {
|
ExprKind::MethodCall(method, [_value], _) => {
|
||||||
if method.ident.name.as_str() == "signum" {
|
if method.ident.name.as_str() == "signum" {
|
||||||
0 // do not lint if cast comes from a `signum` function
|
0 // do not lint if cast comes from a `signum` function
|
||||||
} else {
|
} else {
|
||||||
|
@ -19,7 +19,7 @@ pub(super) fn check(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
|||||||
cx.typeck_results().expr_ty(expr),
|
cx.typeck_results().expr_ty(expr),
|
||||||
);
|
);
|
||||||
lint_cast_ptr_alignment(cx, expr, cast_from, cast_to);
|
lint_cast_ptr_alignment(cx, expr, cast_from, cast_to);
|
||||||
} else if let ExprKind::MethodCall(method_path, _, [self_arg, ..], _) = &expr.kind {
|
} else if let ExprKind::MethodCall(method_path, [self_arg, ..], _) = &expr.kind {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if method_path.ident.name == sym!(cast);
|
if method_path.ident.name == sym!(cast);
|
||||||
if let Some(generic_args) = method_path.args;
|
if let Some(generic_args) = method_path.args;
|
||||||
|
@ -41,14 +41,14 @@ fn should_lint(cx: &LateContext<'_>, cast_op: &Expr<'_>, cast_from: Ty<'_>, cast
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Don't lint for the result of methods that always return non-negative values.
|
// Don't lint for the result of methods that always return non-negative values.
|
||||||
if let ExprKind::MethodCall(path, _, _, _) = cast_op.kind {
|
if let ExprKind::MethodCall(path, _, _) = cast_op.kind {
|
||||||
let mut method_name = path.ident.name.as_str();
|
let mut method_name = path.ident.name.as_str();
|
||||||
let allowed_methods = ["abs", "checked_abs", "rem_euclid", "checked_rem_euclid"];
|
let allowed_methods = ["abs", "checked_abs", "rem_euclid", "checked_rem_euclid"];
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if method_name == "unwrap";
|
if method_name == "unwrap";
|
||||||
if let Some(arglist) = method_chain_args(cast_op, &["unwrap"]);
|
if let Some(arglist) = method_chain_args(cast_op, &["unwrap"]);
|
||||||
if let ExprKind::MethodCall(inner_path, _, _, _) = &arglist[0][0].kind;
|
if let ExprKind::MethodCall(inner_path, _, _) = &arglist[0][0].kind;
|
||||||
then {
|
then {
|
||||||
method_name = inner_path.ident.name.as_str();
|
method_name = inner_path.ident.name.as_str();
|
||||||
}
|
}
|
||||||
|
@ -131,7 +131,7 @@ impl<'a, 'tcx> Visitor<'tcx> for NumericFallbackVisitor<'a, 'tcx> {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
ExprKind::MethodCall(_, _, args, _) => {
|
ExprKind::MethodCall(_, args, _) => {
|
||||||
if let Some(def_id) = self.cx.typeck_results().type_dependent_def_id(expr.hir_id) {
|
if let Some(def_id) = self.cx.typeck_results().type_dependent_def_id(expr.hir_id) {
|
||||||
let fn_sig = self.cx.tcx.fn_sig(def_id).skip_binder();
|
let fn_sig = self.cx.tcx.fn_sig(def_id).skip_binder();
|
||||||
for (expr, bound) in iter::zip(*args, fn_sig.inputs()) {
|
for (expr, bound) in iter::zip(*args, fn_sig.inputs()) {
|
||||||
|
@ -361,7 +361,7 @@ fn try_parse_ref_op<'tcx>(
|
|||||||
expr: &'tcx Expr<'_>,
|
expr: &'tcx Expr<'_>,
|
||||||
) -> Option<(RefOp, &'tcx Expr<'tcx>)> {
|
) -> Option<(RefOp, &'tcx Expr<'tcx>)> {
|
||||||
let (def_id, arg) = match expr.kind {
|
let (def_id, arg) = match expr.kind {
|
||||||
ExprKind::MethodCall(_, _, [arg], _) => (typeck.type_dependent_def_id(expr.hir_id)?, arg),
|
ExprKind::MethodCall(_, [arg], _) => (typeck.type_dependent_def_id(expr.hir_id)?, arg),
|
||||||
ExprKind::Call(
|
ExprKind::Call(
|
||||||
Expr {
|
Expr {
|
||||||
kind: ExprKind::Path(path),
|
kind: ExprKind::Path(path),
|
||||||
@ -408,7 +408,7 @@ fn is_linted_explicit_deref_position(parent: Option<Node<'_>>, child_id: HirId,
|
|||||||
match parent.kind {
|
match parent.kind {
|
||||||
// Leave deref calls in the middle of a method chain.
|
// Leave deref calls in the middle of a method chain.
|
||||||
// e.g. x.deref().foo()
|
// e.g. x.deref().foo()
|
||||||
ExprKind::MethodCall(_, _, [self_arg, ..], _) if self_arg.hir_id == child_id => false,
|
ExprKind::MethodCall(_, [self_arg, ..], _) if self_arg.hir_id == child_id => false,
|
||||||
|
|
||||||
// Leave deref calls resulting in a called function
|
// Leave deref calls resulting in a called function
|
||||||
// e.g. (x.deref())()
|
// e.g. (x.deref())()
|
||||||
|
@ -45,7 +45,7 @@ impl<'tcx> LateLintPass<'tcx> for DurationSubsec {
|
|||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::Binary(Spanned { node: BinOpKind::Div, .. }, left, right) = expr.kind;
|
if let ExprKind::Binary(Spanned { node: BinOpKind::Div, .. }, left, right) = expr.kind;
|
||||||
if let ExprKind::MethodCall(method_path, _ , args, _) = left.kind;
|
if let ExprKind::MethodCall(method_path, args, _) = left.kind;
|
||||||
if match_type(cx, cx.typeck_results().expr_ty(&args[0]).peel_refs(), &paths::DURATION);
|
if match_type(cx, cx.typeck_results().expr_ty(&args[0]).peel_refs(), &paths::DURATION);
|
||||||
if let Some((Constant::Int(divisor), _)) = constant(cx, cx.typeck_results(), right);
|
if let Some((Constant::Int(divisor), _)) = constant(cx, cx.typeck_results(), right);
|
||||||
then {
|
then {
|
||||||
|
@ -244,7 +244,6 @@ fn try_parse_contains<'tcx>(cx: &LateContext<'_>, expr: &'tcx Expr<'_>) -> Optio
|
|||||||
});
|
});
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
ExprKind::MethodCall(
|
ExprKind::MethodCall(
|
||||||
_,
|
|
||||||
_,
|
_,
|
||||||
[
|
[
|
||||||
map,
|
map,
|
||||||
@ -281,7 +280,7 @@ struct InsertExpr<'tcx> {
|
|||||||
value: &'tcx Expr<'tcx>,
|
value: &'tcx Expr<'tcx>,
|
||||||
}
|
}
|
||||||
fn try_parse_insert<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) -> Option<InsertExpr<'tcx>> {
|
fn try_parse_insert<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) -> Option<InsertExpr<'tcx>> {
|
||||||
if let ExprKind::MethodCall(_, _, [map, key, value], _) = expr.kind {
|
if let ExprKind::MethodCall(_, [map, key, value], _) = expr.kind {
|
||||||
let id = cx.typeck_results().type_dependent_def_id(expr.hir_id)?;
|
let id = cx.typeck_results().type_dependent_def_id(expr.hir_id)?;
|
||||||
if match_def_path(cx, id, &paths::BTREEMAP_INSERT) || match_def_path(cx, id, &paths::HASHMAP_INSERT) {
|
if match_def_path(cx, id, &paths::BTREEMAP_INSERT) || match_def_path(cx, id, &paths::HASHMAP_INSERT) {
|
||||||
Some(InsertExpr { map, key, value })
|
Some(InsertExpr { map, key, value })
|
||||||
|
@ -144,7 +144,7 @@ impl<'tcx> LateLintPass<'tcx> for EtaReduction {
|
|||||||
);
|
);
|
||||||
|
|
||||||
if_chain!(
|
if_chain!(
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = body.value.kind;
|
if let ExprKind::MethodCall(path, args, _) = body.value.kind;
|
||||||
if check_inputs(cx, body.params, args);
|
if check_inputs(cx, body.params, args);
|
||||||
let method_def_id = cx.typeck_results().type_dependent_def_id(body.value.hir_id).unwrap();
|
let method_def_id = cx.typeck_results().type_dependent_def_id(body.value.hir_id).unwrap();
|
||||||
let substs = cx.typeck_results().node_substs(body.value.hir_id);
|
let substs = cx.typeck_results().node_substs(body.value.hir_id);
|
||||||
|
@ -35,10 +35,10 @@ impl<'tcx> LateLintPass<'tcx> for ExplicitWrite {
|
|||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// match call to unwrap
|
// match call to unwrap
|
||||||
if let ExprKind::MethodCall(unwrap_fun, _, [write_call], _) = expr.kind;
|
if let ExprKind::MethodCall(unwrap_fun, [write_call], _) = expr.kind;
|
||||||
if unwrap_fun.ident.name == sym::unwrap;
|
if unwrap_fun.ident.name == sym::unwrap;
|
||||||
// match call to write_fmt
|
// match call to write_fmt
|
||||||
if let ExprKind::MethodCall(write_fun, _, [write_recv, write_arg], _) = write_call.kind;
|
if let ExprKind::MethodCall(write_fun, [write_recv, write_arg], _) = write_call.kind;
|
||||||
if write_fun.ident.name == sym!(write_fmt);
|
if write_fun.ident.name == sym!(write_fmt);
|
||||||
// match calls to std::io::stdout() / std::io::stderr ()
|
// match calls to std::io::stdout() / std::io::stderr ()
|
||||||
if let Some(dest_name) = if match_function_call(cx, write_recv, &paths::STDOUT).is_some() {
|
if let Some(dest_name) = if match_function_call(cx, write_recv, &paths::STDOUT).is_some() {
|
||||||
|
@ -303,7 +303,7 @@ fn check_powi(cx: &LateContext<'_>, expr: &Expr<'_>, args: &[Expr<'_>]) {
|
|||||||
if value == Int(2) {
|
if value == Int(2) {
|
||||||
if let Some(parent) = get_parent_expr(cx, expr) {
|
if let Some(parent) = get_parent_expr(cx, expr) {
|
||||||
if let Some(grandparent) = get_parent_expr(cx, parent) {
|
if let Some(grandparent) = get_parent_expr(cx, parent) {
|
||||||
if let ExprKind::MethodCall(PathSegment { ident: method_name, .. }, _, args, _) = grandparent.kind {
|
if let ExprKind::MethodCall(PathSegment { ident: method_name, .. }, args, _) = grandparent.kind {
|
||||||
if method_name.as_str() == "sqrt" && detect_hypot(cx, args).is_some() {
|
if method_name.as_str() == "sqrt" && detect_hypot(cx, args).is_some() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -364,13 +364,11 @@ fn detect_hypot(cx: &LateContext<'_>, args: &[Expr<'_>]) -> Option<String> {
|
|||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(
|
if let ExprKind::MethodCall(
|
||||||
PathSegment { ident: lmethod_name, .. },
|
PathSegment { ident: lmethod_name, .. },
|
||||||
_lspan,
|
|
||||||
[largs_0, largs_1, ..],
|
[largs_0, largs_1, ..],
|
||||||
_
|
_
|
||||||
) = &add_lhs.kind;
|
) = &add_lhs.kind;
|
||||||
if let ExprKind::MethodCall(
|
if let ExprKind::MethodCall(
|
||||||
PathSegment { ident: rmethod_name, .. },
|
PathSegment { ident: rmethod_name, .. },
|
||||||
_rspan,
|
|
||||||
[rargs_0, rargs_1, ..],
|
[rargs_0, rargs_1, ..],
|
||||||
_
|
_
|
||||||
) = &add_rhs.kind;
|
) = &add_rhs.kind;
|
||||||
@ -409,7 +407,7 @@ fn check_expm1(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
|||||||
if cx.typeck_results().expr_ty(lhs).is_floating_point();
|
if cx.typeck_results().expr_ty(lhs).is_floating_point();
|
||||||
if let Some((value, _)) = constant(cx, cx.typeck_results(), rhs);
|
if let Some((value, _)) = constant(cx, cx.typeck_results(), rhs);
|
||||||
if F32(1.0) == value || F64(1.0) == value;
|
if F32(1.0) == value || F64(1.0) == value;
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, ..], _) = &lhs.kind;
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &lhs.kind;
|
||||||
if cx.typeck_results().expr_ty(self_arg).is_floating_point();
|
if cx.typeck_results().expr_ty(self_arg).is_floating_point();
|
||||||
if path.ident.name.as_str() == "exp";
|
if path.ident.name.as_str() == "exp";
|
||||||
then {
|
then {
|
||||||
@ -453,7 +451,7 @@ fn check_mul_add(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
|||||||
) = &expr.kind
|
) = &expr.kind
|
||||||
{
|
{
|
||||||
if let Some(parent) = get_parent_expr(cx, expr) {
|
if let Some(parent) = get_parent_expr(cx, expr) {
|
||||||
if let ExprKind::MethodCall(PathSegment { ident: method_name, .. }, _, args, _) = parent.kind {
|
if let ExprKind::MethodCall(PathSegment { ident: method_name, .. }, args, _) = parent.kind {
|
||||||
if method_name.as_str() == "sqrt" && detect_hypot(cx, args).is_some() {
|
if method_name.as_str() == "sqrt" && detect_hypot(cx, args).is_some() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -589,8 +587,8 @@ fn check_custom_abs(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
|||||||
|
|
||||||
fn are_same_base_logs(cx: &LateContext<'_>, expr_a: &Expr<'_>, expr_b: &Expr<'_>) -> bool {
|
fn are_same_base_logs(cx: &LateContext<'_>, expr_a: &Expr<'_>, expr_b: &Expr<'_>) -> bool {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(PathSegment { ident: method_name_a, .. }, _, args_a, _) = expr_a.kind;
|
if let ExprKind::MethodCall(PathSegment { ident: method_name_a, .. }, args_a, _) = expr_a.kind;
|
||||||
if let ExprKind::MethodCall(PathSegment { ident: method_name_b, .. }, _, args_b, _) = expr_b.kind;
|
if let ExprKind::MethodCall(PathSegment { ident: method_name_b, .. }, args_b, _) = expr_b.kind;
|
||||||
then {
|
then {
|
||||||
return method_name_a.as_str() == method_name_b.as_str() &&
|
return method_name_a.as_str() == method_name_b.as_str() &&
|
||||||
args_a.len() == args_b.len() &&
|
args_a.len() == args_b.len() &&
|
||||||
@ -615,8 +613,8 @@ fn check_log_division(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
|||||||
rhs,
|
rhs,
|
||||||
) = &expr.kind;
|
) = &expr.kind;
|
||||||
if are_same_base_logs(cx, lhs, rhs);
|
if are_same_base_logs(cx, lhs, rhs);
|
||||||
if let ExprKind::MethodCall(_, _, [largs_self, ..], _) = &lhs.kind;
|
if let ExprKind::MethodCall(_, [largs_self, ..], _) = &lhs.kind;
|
||||||
if let ExprKind::MethodCall(_, _, [rargs_self, ..], _) = &rhs.kind;
|
if let ExprKind::MethodCall(_, [rargs_self, ..], _) = &rhs.kind;
|
||||||
then {
|
then {
|
||||||
span_lint_and_sugg(
|
span_lint_and_sugg(
|
||||||
cx,
|
cx,
|
||||||
@ -714,7 +712,7 @@ impl<'tcx> LateLintPass<'tcx> for FloatingPointArithmetic {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = &expr.kind {
|
if let ExprKind::MethodCall(path, args, _) = &expr.kind {
|
||||||
let recv_ty = cx.typeck_results().expr_ty(&args[0]);
|
let recv_ty = cx.typeck_results().expr_ty(&args[0]);
|
||||||
|
|
||||||
if recv_ty.is_floating_point() {
|
if recv_ty.is_floating_point() {
|
||||||
|
@ -149,7 +149,7 @@ fn check_format_in_format_args(cx: &LateContext<'_>, call_site: Span, name: Symb
|
|||||||
fn check_to_string_in_format_args(cx: &LateContext<'_>, name: Symbol, value: &Expr<'_>) {
|
fn check_to_string_in_format_args(cx: &LateContext<'_>, name: Symbol, value: &Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if !value.span.from_expansion();
|
if !value.span.from_expansion();
|
||||||
if let ExprKind::MethodCall(_, _, [receiver], _) = value.kind;
|
if let ExprKind::MethodCall(_, [receiver], _) = value.kind;
|
||||||
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(value.hir_id);
|
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(value.hir_id);
|
||||||
if is_diag_trait_item(cx, method_def_id, sym::ToString);
|
if is_diag_trait_item(cx, method_def_id, sym::ToString);
|
||||||
let receiver_ty = cx.typeck_results().expr_ty(receiver);
|
let receiver_ty = cx.typeck_results().expr_ty(receiver);
|
||||||
|
@ -217,7 +217,7 @@ impl<'a, 'tcx> intravisit::Visitor<'tcx> for StaticMutVisitor<'a, 'tcx> {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
Call(_, args) | MethodCall(_, _, args, _) => {
|
Call(_, args) | MethodCall(_, args, _) => {
|
||||||
let mut tys = DefIdSet::default();
|
let mut tys = DefIdSet::default();
|
||||||
for arg in args {
|
for arg in args {
|
||||||
if self.cx.tcx.has_typeck_results(arg.hir_id.owner.to_def_id())
|
if self.cx.tcx.has_typeck_results(arg.hir_id.owner.to_def_id())
|
||||||
|
@ -88,7 +88,7 @@ impl<'a, 'tcx> intravisit::Visitor<'tcx> for DerefVisitor<'a, 'tcx> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
hir::ExprKind::MethodCall(_, _, args, _) => {
|
hir::ExprKind::MethodCall(_, args, _) => {
|
||||||
let def_id = self.typeck_results.type_dependent_def_id(expr.hir_id).unwrap();
|
let def_id = self.typeck_results.type_dependent_def_id(expr.hir_id).unwrap();
|
||||||
let base_type = self.cx.tcx.type_of(def_id);
|
let base_type = self.cx.tcx.type_of(def_id);
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ impl<'tcx> LateLintPass<'tcx> for GetLastWithLen {
|
|||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// Is a method call
|
// Is a method call
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = expr.kind;
|
if let ExprKind::MethodCall(path, args, _) = expr.kind;
|
||||||
|
|
||||||
// Method name is "get"
|
// Method name is "get"
|
||||||
if path.ident.name == sym!(get);
|
if path.ident.name == sym!(get);
|
||||||
@ -73,7 +73,7 @@ impl<'tcx> LateLintPass<'tcx> for GetLastWithLen {
|
|||||||
) = &get_index_arg.kind;
|
) = &get_index_arg.kind;
|
||||||
|
|
||||||
// LHS of subtraction is "x.len()"
|
// LHS of subtraction is "x.len()"
|
||||||
if let ExprKind::MethodCall(arg_lhs_path, _, lhs_args, _) = &lhs.kind;
|
if let ExprKind::MethodCall(arg_lhs_path, lhs_args, _) = &lhs.kind;
|
||||||
if arg_lhs_path.ident.name == sym::len;
|
if arg_lhs_path.ident.name == sym::len;
|
||||||
if let Some(arg_lhs_struct) = lhs_args.get(0);
|
if let Some(arg_lhs_struct) = lhs_args.get(0);
|
||||||
|
|
||||||
|
@ -127,7 +127,7 @@ impl<'tcx, 'l> ArmVisitor<'tcx, 'l> {
|
|||||||
|
|
||||||
fn is_mutex_lock_call<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) -> Option<&'tcx Expr<'tcx>> {
|
fn is_mutex_lock_call<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) -> Option<&'tcx Expr<'tcx>> {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _span, [self_arg, ..], _) = &expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &expr.kind;
|
||||||
if path.ident.as_str() == "lock";
|
if path.ident.as_str() == "lock";
|
||||||
let ty = cx.typeck_results().expr_ty(self_arg);
|
let ty = cx.typeck_results().expr_ty(self_arg);
|
||||||
if is_type_diagnostic_item(cx, ty, sym::Mutex);
|
if is_type_diagnostic_item(cx, ty, sym::Mutex);
|
||||||
|
@ -145,7 +145,7 @@ const HEURISTICS: [(&str, usize, Heuristic, Finiteness); 19] = [
|
|||||||
|
|
||||||
fn is_infinite(cx: &LateContext<'_>, expr: &Expr<'_>) -> Finiteness {
|
fn is_infinite(cx: &LateContext<'_>, expr: &Expr<'_>) -> Finiteness {
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
ExprKind::MethodCall(method, _, args, _) => {
|
ExprKind::MethodCall(method, args, _) => {
|
||||||
for &(name, len, heuristic, cap) in &HEURISTICS {
|
for &(name, len, heuristic, cap) in &HEURISTICS {
|
||||||
if method.ident.name.as_str() == name && args.len() == len {
|
if method.ident.name.as_str() == name && args.len() == len {
|
||||||
return (match heuristic {
|
return (match heuristic {
|
||||||
@ -221,7 +221,7 @@ const INFINITE_COLLECTORS: &[Symbol] = &[
|
|||||||
|
|
||||||
fn complete_infinite_iter(cx: &LateContext<'_>, expr: &Expr<'_>) -> Finiteness {
|
fn complete_infinite_iter(cx: &LateContext<'_>, expr: &Expr<'_>) -> Finiteness {
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
ExprKind::MethodCall(method, _, args, _) => {
|
ExprKind::MethodCall(method, args, _) => {
|
||||||
for &(name, len) in &COMPLETING_METHODS {
|
for &(name, len) in &COMPLETING_METHODS {
|
||||||
if method.ident.name.as_str() == name && args.len() == len {
|
if method.ident.name.as_str() == name && args.len() == len {
|
||||||
return is_infinite(cx, &args[0]);
|
return is_infinite(cx, &args[0]);
|
||||||
|
@ -370,7 +370,7 @@ fn check_for_is_empty(
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn check_cmp(cx: &LateContext<'_>, span: Span, method: &Expr<'_>, lit: &Expr<'_>, op: &str, compare_to: u32) {
|
fn check_cmp(cx: &LateContext<'_>, span: Span, method: &Expr<'_>, lit: &Expr<'_>, op: &str, compare_to: u32) {
|
||||||
if let (&ExprKind::MethodCall(method_path, _, args, _), &ExprKind::Lit(ref lit)) = (&method.kind, &lit.kind) {
|
if let (&ExprKind::MethodCall(method_path, args, _), &ExprKind::Lit(ref lit)) = (&method.kind, &lit.kind) {
|
||||||
// check if we are in an is_empty() method
|
// check if we are in an is_empty() method
|
||||||
if let Some(name) = get_item_name(cx, method) {
|
if let Some(name) = get_item_name(cx, method) {
|
||||||
if name.as_str() == "is_empty" {
|
if name.as_str() == "is_empty" {
|
||||||
|
@ -119,7 +119,7 @@ fn build_manual_memcpy_suggestion<'tcx>(
|
|||||||
|
|
||||||
let print_limit = |end: &Expr<'_>, end_str: &str, base: &Expr<'_>, sugg: MinifyingSugg<'static>| {
|
let print_limit = |end: &Expr<'_>, end_str: &str, base: &Expr<'_>, sugg: MinifyingSugg<'static>| {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method, _, len_args, _) = end.kind;
|
if let ExprKind::MethodCall(method, len_args, _) = end.kind;
|
||||||
if method.ident.name == sym::len;
|
if method.ident.name == sym::len;
|
||||||
if len_args.len() == 1;
|
if len_args.len() == 1;
|
||||||
if let Some(arg) = len_args.get(0);
|
if let Some(arg) = len_args.get(0);
|
||||||
@ -343,7 +343,7 @@ fn get_slice_like_element_ty<'tcx>(cx: &LateContext<'tcx>, ty: Ty<'tcx>) -> Opti
|
|||||||
|
|
||||||
fn fetch_cloned_expr<'tcx>(expr: &'tcx Expr<'tcx>) -> &'tcx Expr<'tcx> {
|
fn fetch_cloned_expr<'tcx>(expr: &'tcx Expr<'tcx>) -> &'tcx Expr<'tcx> {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method, _, args, _) = expr.kind;
|
if let ExprKind::MethodCall(method, args, _) = expr.kind;
|
||||||
if method.ident.name == sym::clone;
|
if method.ident.name == sym::clone;
|
||||||
if args.len() == 1;
|
if args.len() == 1;
|
||||||
if let Some(arg) = args.get(0);
|
if let Some(arg) = args.get(0);
|
||||||
|
@ -658,7 +658,7 @@ fn check_for_loop<'tcx>(
|
|||||||
fn check_for_loop_arg(cx: &LateContext<'_>, pat: &Pat<'_>, arg: &Expr<'_>) {
|
fn check_for_loop_arg(cx: &LateContext<'_>, pat: &Pat<'_>, arg: &Expr<'_>) {
|
||||||
let mut next_loop_linted = false; // whether or not ITER_NEXT_LOOP lint was used
|
let mut next_loop_linted = false; // whether or not ITER_NEXT_LOOP lint was used
|
||||||
|
|
||||||
if let ExprKind::MethodCall(method, _, [self_arg], _) = arg.kind {
|
if let ExprKind::MethodCall(method, [self_arg], _) = arg.kind {
|
||||||
let method_name = method.ident.as_str();
|
let method_name = method.ident.as_str();
|
||||||
// check for looping over x.iter() or x.iter_mut(), could use &x or &mut x
|
// check for looping over x.iter() or x.iter_mut(), could use &x or &mut x
|
||||||
match method_name {
|
match method_name {
|
||||||
|
@ -24,8 +24,8 @@ pub(super) fn check<'tcx>(expr: &'tcx Expr<'_>, cx: &LateContext<'tcx>) {
|
|||||||
}
|
}
|
||||||
fn check_needless_collect_direct_usage<'tcx>(expr: &'tcx Expr<'_>, cx: &LateContext<'tcx>) {
|
fn check_needless_collect_direct_usage<'tcx>(expr: &'tcx Expr<'_>, cx: &LateContext<'tcx>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method, _, args, _) = expr.kind;
|
if let ExprKind::MethodCall(method, args, _) = expr.kind;
|
||||||
if let ExprKind::MethodCall(chain_method, method0_span, _, _) = args[0].kind;
|
if let ExprKind::MethodCall(chain_method, _, _) = args[0].kind;
|
||||||
if chain_method.ident.name == sym!(collect) && is_trait_method(cx, &args[0], sym::Iterator);
|
if chain_method.ident.name == sym!(collect) && is_trait_method(cx, &args[0], sym::Iterator);
|
||||||
then {
|
then {
|
||||||
let ty = cx.typeck_results().expr_ty(&args[0]);
|
let ty = cx.typeck_results().expr_ty(&args[0]);
|
||||||
@ -62,7 +62,7 @@ fn check_needless_collect_direct_usage<'tcx>(expr: &'tcx Expr<'_>, cx: &LateCont
|
|||||||
span_lint_and_sugg(
|
span_lint_and_sugg(
|
||||||
cx,
|
cx,
|
||||||
NEEDLESS_COLLECT,
|
NEEDLESS_COLLECT,
|
||||||
method0_span.with_hi(expr.span.hi()),
|
chain_method.ident.span.with_hi(expr.span.hi()),
|
||||||
NEEDLESS_COLLECT_MSG,
|
NEEDLESS_COLLECT_MSG,
|
||||||
"replace with",
|
"replace with",
|
||||||
sugg,
|
sugg,
|
||||||
@ -79,7 +79,7 @@ fn check_needless_collect_indirect_usage<'tcx>(expr: &'tcx Expr<'_>, cx: &LateCo
|
|||||||
if let StmtKind::Local(local) = stmt.kind;
|
if let StmtKind::Local(local) = stmt.kind;
|
||||||
if let PatKind::Binding(_, id, ..) = local.pat.kind;
|
if let PatKind::Binding(_, id, ..) = local.pat.kind;
|
||||||
if let Some(init_expr) = local.init;
|
if let Some(init_expr) = local.init;
|
||||||
if let ExprKind::MethodCall(method_name, collect_span, &[ref iter_source], ..) = init_expr.kind;
|
if let ExprKind::MethodCall(method_name, &[ref iter_source], ..) = init_expr.kind;
|
||||||
if method_name.ident.name == sym!(collect) && is_trait_method(cx, init_expr, sym::Iterator);
|
if method_name.ident.name == sym!(collect) && is_trait_method(cx, init_expr, sym::Iterator);
|
||||||
let ty = cx.typeck_results().expr_ty(init_expr);
|
let ty = cx.typeck_results().expr_ty(init_expr);
|
||||||
if is_type_diagnostic_item(cx, ty, sym::Vec) ||
|
if is_type_diagnostic_item(cx, ty, sym::Vec) ||
|
||||||
@ -101,7 +101,7 @@ fn check_needless_collect_indirect_usage<'tcx>(expr: &'tcx Expr<'_>, cx: &LateCo
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Suggest replacing iter_call with iter_replacement, and removing stmt
|
// Suggest replacing iter_call with iter_replacement, and removing stmt
|
||||||
let mut span = MultiSpan::from_span(collect_span);
|
let mut span = MultiSpan::from_span(method_name.ident.span);
|
||||||
span.push_span_label(iter_call.span, "the iterator could be used here instead".into());
|
span.push_span_label(iter_call.span, "the iterator could be used here instead".into());
|
||||||
span_lint_hir_and_then(
|
span_lint_hir_and_then(
|
||||||
cx,
|
cx,
|
||||||
@ -193,7 +193,7 @@ impl<'tcx> Visitor<'tcx> for IterFunctionVisitor<'_, 'tcx> {
|
|||||||
|
|
||||||
fn visit_expr(&mut self, expr: &'tcx Expr<'tcx>) {
|
fn visit_expr(&mut self, expr: &'tcx Expr<'tcx>) {
|
||||||
// Check function calls on our collection
|
// Check function calls on our collection
|
||||||
if let ExprKind::MethodCall(method_name, _, [recv, args @ ..], _) = &expr.kind {
|
if let ExprKind::MethodCall(method_name, [recv, args @ ..], _) = &expr.kind {
|
||||||
if method_name.ident.name == sym!(collect) && is_trait_method(self.cx, expr, sym::Iterator) {
|
if method_name.ident.name == sym!(collect) && is_trait_method(self.cx, expr, sym::Iterator) {
|
||||||
self.current_mutably_captured_ids = get_captured_ids(self.cx, self.cx.typeck_results().expr_ty(recv));
|
self.current_mutably_captured_ids = get_captured_ids(self.cx, self.cx.typeck_results().expr_ty(recv));
|
||||||
self.visit_expr(recv);
|
self.visit_expr(recv);
|
||||||
|
@ -186,7 +186,7 @@ pub(super) fn check<'tcx>(
|
|||||||
|
|
||||||
fn is_len_call(expr: &Expr<'_>, var: Symbol) -> bool {
|
fn is_len_call(expr: &Expr<'_>, var: Symbol) -> bool {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method, _, len_args, _) = expr.kind;
|
if let ExprKind::MethodCall(method, len_args, _) = expr.kind;
|
||||||
if len_args.len() == 1;
|
if len_args.len() == 1;
|
||||||
if method.ident.name == sym::len;
|
if method.ident.name == sym::len;
|
||||||
if let ExprKind::Path(QPath::Resolved(_, path)) = len_args[0].kind;
|
if let ExprKind::Path(QPath::Resolved(_, path)) = len_args[0].kind;
|
||||||
@ -296,7 +296,7 @@ impl<'a, 'tcx> Visitor<'tcx> for VarVisitor<'a, 'tcx> {
|
|||||||
fn visit_expr(&mut self, expr: &'tcx Expr<'_>) {
|
fn visit_expr(&mut self, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// a range index op
|
// a range index op
|
||||||
if let ExprKind::MethodCall(meth, _, [args_0, args_1, ..], _) = &expr.kind;
|
if let ExprKind::MethodCall(meth, [args_0, args_1, ..], _) = &expr.kind;
|
||||||
if (meth.ident.name == sym::index && match_trait_method(self.cx, expr, &paths::INDEX))
|
if (meth.ident.name == sym::index && match_trait_method(self.cx, expr, &paths::INDEX))
|
||||||
|| (meth.ident.name == sym::index_mut && match_trait_method(self.cx, expr, &paths::INDEX_MUT));
|
|| (meth.ident.name == sym::index_mut && match_trait_method(self.cx, expr, &paths::INDEX_MUT));
|
||||||
if !self.check(args_1, args_0, expr);
|
if !self.check(args_1, args_0, expr);
|
||||||
@ -351,7 +351,7 @@ impl<'a, 'tcx> Visitor<'tcx> for VarVisitor<'a, 'tcx> {
|
|||||||
self.visit_expr(expr);
|
self.visit_expr(expr);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(_, _, args, _) => {
|
ExprKind::MethodCall(_, args, _) => {
|
||||||
let def_id = self.cx.typeck_results().type_dependent_def_id(expr.hir_id).unwrap();
|
let def_id = self.cx.typeck_results().type_dependent_def_id(expr.hir_id).unwrap();
|
||||||
for (ty, expr) in iter::zip(self.cx.tcx.fn_sig(def_id).inputs().skip_binder(), args) {
|
for (ty, expr) in iter::zip(self.cx.tcx.fn_sig(def_id).inputs().skip_binder(), args) {
|
||||||
self.prefer_mutable = false;
|
self.prefer_mutable = false;
|
||||||
|
@ -121,7 +121,7 @@ fn never_loop_expr(expr: &Expr<'_>, main_loop_id: HirId) -> NeverLoopResult {
|
|||||||
| ExprKind::Repeat(e, _)
|
| ExprKind::Repeat(e, _)
|
||||||
| ExprKind::DropTemps(e) => never_loop_expr(e, main_loop_id),
|
| ExprKind::DropTemps(e) => never_loop_expr(e, main_loop_id),
|
||||||
ExprKind::Let(let_expr) => never_loop_expr(let_expr.init, main_loop_id),
|
ExprKind::Let(let_expr) => never_loop_expr(let_expr.init, main_loop_id),
|
||||||
ExprKind::Array(es) | ExprKind::MethodCall(_, _, es, _) | ExprKind::Tup(es) => {
|
ExprKind::Array(es) | ExprKind::MethodCall(_, es, _) | ExprKind::Tup(es) => {
|
||||||
never_loop_expr_all(&mut es.iter(), main_loop_id)
|
never_loop_expr_all(&mut es.iter(), main_loop_id)
|
||||||
},
|
},
|
||||||
ExprKind::Call(e, es) => never_loop_expr_all(&mut once(e).chain(es.iter()), main_loop_id),
|
ExprKind::Call(e, es) => never_loop_expr_all(&mut once(e).chain(es.iter()), main_loop_id),
|
||||||
|
@ -180,7 +180,7 @@ fn get_vec_push<'tcx>(cx: &LateContext<'tcx>, stmt: &'tcx Stmt<'_>) -> Option<(&
|
|||||||
if_chain! {
|
if_chain! {
|
||||||
// Extract method being called
|
// Extract method being called
|
||||||
if let StmtKind::Semi(semi_stmt) = &stmt.kind;
|
if let StmtKind::Semi(semi_stmt) = &stmt.kind;
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = &semi_stmt.kind;
|
if let ExprKind::MethodCall(path, args, _) = &semi_stmt.kind;
|
||||||
// Figure out the parameters for the method call
|
// Figure out the parameters for the method call
|
||||||
if let Some(self_expr) = args.get(0);
|
if let Some(self_expr) = args.get(0);
|
||||||
if let Some(pushed_item) = args.get(1);
|
if let Some(pushed_item) = args.get(1);
|
||||||
|
@ -16,7 +16,7 @@ pub(super) fn check<'tcx>(
|
|||||||
) {
|
) {
|
||||||
let arg_expr = match arg.kind {
|
let arg_expr = match arg.kind {
|
||||||
ExprKind::AddrOf(BorrowKind::Ref, _, ref_arg) => ref_arg,
|
ExprKind::AddrOf(BorrowKind::Ref, _, ref_arg) => ref_arg,
|
||||||
ExprKind::MethodCall(method, _, args, _) if args.len() == 1 && method.ident.name == rustc_span::sym::iter => {
|
ExprKind::MethodCall(method, args, _) if args.len() == 1 && method.ident.name == rustc_span::sym::iter => {
|
||||||
&args[0]
|
&args[0]
|
||||||
},
|
},
|
||||||
_ => return,
|
_ => return,
|
||||||
|
@ -21,7 +21,7 @@ pub(super) fn check<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
|||||||
if let Res::Def(_, pat_did) = pat_path.res;
|
if let Res::Def(_, pat_did) = pat_path.res;
|
||||||
if match_def_path(cx, pat_did, &paths::OPTION_SOME);
|
if match_def_path(cx, pat_did, &paths::OPTION_SOME);
|
||||||
// check for call to `Iterator::next`
|
// check for call to `Iterator::next`
|
||||||
if let ExprKind::MethodCall(method_name, _, [iter_expr], _) = let_expr.kind;
|
if let ExprKind::MethodCall(method_name, [iter_expr], _) = let_expr.kind;
|
||||||
if method_name.ident.name == sym::next;
|
if method_name.ident.name == sym::next;
|
||||||
if is_trait_method(cx, let_expr, sym::Iterator);
|
if is_trait_method(cx, let_expr, sym::Iterator);
|
||||||
if let Some(iter_expr_struct) = try_parse_iter_expr(cx, iter_expr);
|
if let Some(iter_expr_struct) = try_parse_iter_expr(cx, iter_expr);
|
||||||
|
@ -47,7 +47,7 @@ impl<'tcx> LateLintPass<'tcx> for ManualOkOr {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_segment, _, args, _) = scrutinee.kind;
|
if let ExprKind::MethodCall(method_segment, args, _) = scrutinee.kind;
|
||||||
if method_segment.ident.name == sym!(map_or);
|
if method_segment.ident.name == sym!(map_or);
|
||||||
if args.len() == 3;
|
if args.len() == 3;
|
||||||
let method_receiver = &args[0];
|
let method_receiver = &args[0];
|
||||||
|
@ -74,7 +74,7 @@ impl<'tcx> LateLintPass<'tcx> for ManualStrip {
|
|||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let Some(higher::If { cond, then, .. }) = higher::If::hir(expr);
|
if let Some(higher::If { cond, then, .. }) = higher::If::hir(expr);
|
||||||
if let ExprKind::MethodCall(_, _, [target_arg, pattern], _) = cond.kind;
|
if let ExprKind::MethodCall(_, [target_arg, pattern], _) = cond.kind;
|
||||||
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(cond.hir_id);
|
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(cond.hir_id);
|
||||||
if let ExprKind::Path(target_path) = &target_arg.kind;
|
if let ExprKind::Path(target_path) = &target_arg.kind;
|
||||||
then {
|
then {
|
||||||
@ -132,7 +132,7 @@ impl<'tcx> LateLintPass<'tcx> for ManualStrip {
|
|||||||
// Returns `Some(arg)` if `expr` matches `arg.len()` and `None` otherwise.
|
// Returns `Some(arg)` if `expr` matches `arg.len()` and `None` otherwise.
|
||||||
fn len_arg<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) -> Option<&'tcx Expr<'tcx>> {
|
fn len_arg<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) -> Option<&'tcx Expr<'tcx>> {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(_, _, [arg], _) = expr.kind;
|
if let ExprKind::MethodCall(_, [arg], _) = expr.kind;
|
||||||
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
||||||
if match_def_path(cx, method_def_id, &paths::STR_LEN);
|
if match_def_path(cx, method_def_id, &paths::STR_LEN);
|
||||||
then {
|
then {
|
||||||
|
@ -51,7 +51,7 @@ impl<'tcx> LateLintPass<'tcx> for MapClone {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let hir::ExprKind::MethodCall(method, _, args, _) = e.kind;
|
if let hir::ExprKind::MethodCall(method, args, _) = e.kind;
|
||||||
if args.len() == 2;
|
if args.len() == 2;
|
||||||
if method.ident.name == sym::map;
|
if method.ident.name == sym::map;
|
||||||
let ty = cx.typeck_results().expr_ty(&args[0]);
|
let ty = cx.typeck_results().expr_ty(&args[0]);
|
||||||
@ -77,7 +77,7 @@ impl<'tcx> LateLintPass<'tcx> for MapClone {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
hir::ExprKind::MethodCall(method, _, [obj], _) => if_chain! {
|
hir::ExprKind::MethodCall(method, [obj], _) => if_chain! {
|
||||||
if ident_eq(name, obj) && method.ident.name == sym::clone;
|
if ident_eq(name, obj) && method.ident.name == sym::clone;
|
||||||
if let Some(fn_id) = cx.typeck_results().type_dependent_def_id(closure_expr.hir_id);
|
if let Some(fn_id) = cx.typeck_results().type_dependent_def_id(closure_expr.hir_id);
|
||||||
if let Some(trait_id) = cx.tcx.trait_of_item(fn_id);
|
if let Some(trait_id) = cx.tcx.trait_of_item(fn_id);
|
||||||
|
@ -113,7 +113,7 @@ impl<'tcx> LateLintPass<'tcx> for MapErrIgnore {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check if this is a method call (e.g. x.foo())
|
// check if this is a method call (e.g. x.foo())
|
||||||
if let ExprKind::MethodCall(method, _t_span, args, _) = e.kind {
|
if let ExprKind::MethodCall(method, args, _) = e.kind {
|
||||||
// only work if the method name is `map_err` and there are only 2 arguments (e.g. x.map_err(|_|[1]
|
// only work if the method name is `map_err` and there are only 2 arguments (e.g. x.map_err(|_|[1]
|
||||||
// Enum::Variant[2]))
|
// Enum::Variant[2]))
|
||||||
if method.ident.as_str() == "map_err" && args.len() == 2 {
|
if method.ident.as_str() == "map_err" && args.len() == 2 {
|
||||||
|
@ -129,7 +129,7 @@ fn reduce_unit_expression<'a>(cx: &LateContext<'_>, expr: &'a hir::Expr<'_>) ->
|
|||||||
}
|
}
|
||||||
|
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
hir::ExprKind::Call(_, _) | hir::ExprKind::MethodCall(_, _, _, _) => {
|
hir::ExprKind::Call(_, _) | hir::ExprKind::MethodCall(..) => {
|
||||||
// Calls can't be reduced any more
|
// Calls can't be reduced any more
|
||||||
Some(expr.span)
|
Some(expr.span)
|
||||||
},
|
},
|
||||||
|
@ -58,7 +58,7 @@ impl<'tcx> LateLintPass<'tcx> for MatchResultOk {
|
|||||||
};
|
};
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(_, ok_span, [ref result_types_0, ..], _) = let_expr.kind; //check is expr.ok() has type Result<T,E>.ok(, _)
|
if let ExprKind::MethodCall(ok_path, [ref result_types_0, ..], _) = let_expr.kind; //check is expr.ok() has type Result<T,E>.ok(, _)
|
||||||
if let PatKind::TupleStruct(QPath::Resolved(_, x), y, _) = let_pat.kind; //get operation
|
if let PatKind::TupleStruct(QPath::Resolved(_, x), y, _) = let_pat.kind; //get operation
|
||||||
if method_chain_args(let_expr, &["ok"]).is_some(); //test to see if using ok() methoduse std::marker::Sized;
|
if method_chain_args(let_expr, &["ok"]).is_some(); //test to see if using ok() methoduse std::marker::Sized;
|
||||||
if is_type_diagnostic_item(cx, cx.typeck_results().expr_ty(result_types_0), sym::Result);
|
if is_type_diagnostic_item(cx, cx.typeck_results().expr_ty(result_types_0), sym::Result);
|
||||||
@ -68,7 +68,7 @@ impl<'tcx> LateLintPass<'tcx> for MatchResultOk {
|
|||||||
|
|
||||||
let mut applicability = Applicability::MachineApplicable;
|
let mut applicability = Applicability::MachineApplicable;
|
||||||
let some_expr_string = snippet_with_applicability(cx, y[0].span, "", &mut applicability);
|
let some_expr_string = snippet_with_applicability(cx, y[0].span, "", &mut applicability);
|
||||||
let trimmed_ok = snippet_with_applicability(cx, let_expr.span.until(ok_span), "", &mut applicability);
|
let trimmed_ok = snippet_with_applicability(cx, let_expr.span.until(ok_path.ident.span), "", &mut applicability);
|
||||||
let sugg = format!(
|
let sugg = format!(
|
||||||
"{} let Ok({}) = {}",
|
"{} let Ok({}) = {}",
|
||||||
ifwhile,
|
ifwhile,
|
||||||
|
@ -87,8 +87,7 @@ struct MatchExprVisitor<'a, 'tcx> {
|
|||||||
impl<'a, 'tcx> Visitor<'tcx> for MatchExprVisitor<'a, 'tcx> {
|
impl<'a, 'tcx> Visitor<'tcx> for MatchExprVisitor<'a, 'tcx> {
|
||||||
fn visit_expr(&mut self, ex: &'tcx Expr<'_>) {
|
fn visit_expr(&mut self, ex: &'tcx Expr<'_>) {
|
||||||
match ex.kind {
|
match ex.kind {
|
||||||
ExprKind::MethodCall(segment, _, [receiver], _) if self.case_altered(segment.ident.as_str(), receiver) => {
|
ExprKind::MethodCall(segment, [receiver], _) if self.case_altered(segment.ident.as_str(), receiver) => {},
|
||||||
},
|
|
||||||
_ => walk_expr(self, ex),
|
_ => walk_expr(self, ex),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1909,7 +1909,7 @@ mod redundant_pattern_match {
|
|||||||
},
|
},
|
||||||
// Method calls can take self by reference.
|
// Method calls can take self by reference.
|
||||||
// e.g. In `String::new().len()` the string is a temporary value.
|
// e.g. In `String::new().len()` the string is a temporary value.
|
||||||
ExprKind::MethodCall(_, _, [self_arg, args @ ..], _) => {
|
ExprKind::MethodCall(_, [self_arg, args @ ..], _) => {
|
||||||
if !matches!(self_arg.kind, ExprKind::Path(_)) {
|
if !matches!(self_arg.kind, ExprKind::Path(_)) {
|
||||||
let self_by_ref = self
|
let self_by_ref = self
|
||||||
.cx
|
.cx
|
||||||
@ -2020,7 +2020,7 @@ mod redundant_pattern_match {
|
|||||||
// check that `while_let_on_iterator` lint does not trigger
|
// check that `while_let_on_iterator` lint does not trigger
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if keyword == "while";
|
if keyword == "while";
|
||||||
if let ExprKind::MethodCall(method_path, _, _, _) = let_expr.kind;
|
if let ExprKind::MethodCall(method_path, _, _) = let_expr.kind;
|
||||||
if method_path.ident.name == sym::next;
|
if method_path.ident.name == sym::next;
|
||||||
if is_trait_method(cx, let_expr, sym::Iterator);
|
if is_trait_method(cx, let_expr, sym::Iterator);
|
||||||
then {
|
then {
|
||||||
|
@ -121,9 +121,9 @@ pub(crate) trait BindInsteadOfMap {
|
|||||||
});
|
});
|
||||||
let (span, msg) = if_chain! {
|
let (span, msg) = if_chain! {
|
||||||
if can_sugg;
|
if can_sugg;
|
||||||
if let hir::ExprKind::MethodCall(_, span, ..) = expr.kind;
|
if let hir::ExprKind::MethodCall(segment, ..) = expr.kind;
|
||||||
if let Some(msg) = Self::lint_msg(cx);
|
if let Some(msg) = Self::lint_msg(cx);
|
||||||
then { (span, msg) } else { return false; }
|
then { (segment.ident.span, msg) } else { return false; }
|
||||||
};
|
};
|
||||||
span_lint_and_then(cx, BIND_INSTEAD_OF_MAP, expr.span, &msg, |diag| {
|
span_lint_and_then(cx, BIND_INSTEAD_OF_MAP, expr.span, &msg, |diag| {
|
||||||
multispan_sugg_with_applicability(
|
multispan_sugg_with_applicability(
|
||||||
|
@ -81,12 +81,12 @@ pub(super) fn check(cx: &LateContext<'_>, expr: &Expr<'_>, method_name: Symbol,
|
|||||||
// &*x is a nop, &x.clone() is not
|
// &*x is a nop, &x.clone() is not
|
||||||
ExprKind::AddrOf(..) => return,
|
ExprKind::AddrOf(..) => return,
|
||||||
// (*x).func() is useless, x.clone().func() can work in case func borrows self
|
// (*x).func() is useless, x.clone().func() can work in case func borrows self
|
||||||
ExprKind::MethodCall(_, _, [self_arg, ..], _)
|
ExprKind::MethodCall(_, [self_arg, ..], _)
|
||||||
if expr.hir_id == self_arg.hir_id && ty != cx.typeck_results().expr_ty_adjusted(expr) =>
|
if expr.hir_id == self_arg.hir_id && ty != cx.typeck_results().expr_ty_adjusted(expr) =>
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(_, _, [self_arg, ..], _) if expr.hir_id == self_arg.hir_id => true,
|
ExprKind::MethodCall(_, [self_arg, ..], _) if expr.hir_id == self_arg.hir_id => true,
|
||||||
ExprKind::Match(_, _, MatchSource::TryDesugar | MatchSource::AwaitDesugar)
|
ExprKind::Match(_, _, MatchSource::TryDesugar | MatchSource::AwaitDesugar)
|
||||||
| ExprKind::Field(..)
|
| ExprKind::Field(..)
|
||||||
| ExprKind::Index(..) => true,
|
| ExprKind::Index(..) => true,
|
||||||
|
@ -28,7 +28,7 @@ pub(super) fn check<'tcx>(
|
|||||||
loop {
|
loop {
|
||||||
arg_root = match &arg_root.kind {
|
arg_root = match &arg_root.kind {
|
||||||
hir::ExprKind::AddrOf(hir::BorrowKind::Ref, _, expr) => expr,
|
hir::ExprKind::AddrOf(hir::BorrowKind::Ref, _, expr) => expr,
|
||||||
hir::ExprKind::MethodCall(method_name, _, call_args, _) => {
|
hir::ExprKind::MethodCall(method_name, call_args, _) => {
|
||||||
if call_args.len() == 1
|
if call_args.len() == 1
|
||||||
&& (method_name.ident.name == sym::as_str || method_name.ident.name == sym!(as_ref))
|
&& (method_name.ident.name == sym::as_str || method_name.ident.name == sym!(as_ref))
|
||||||
&& {
|
&& {
|
||||||
|
@ -14,7 +14,7 @@ pub(super) fn check(cx: &LateContext<'_>, expr: &Expr<'_>, recv: &Expr<'_>, arg:
|
|||||||
if_chain! {
|
if_chain! {
|
||||||
if is_type_diagnostic_item(cx, ty, sym::Vec);
|
if is_type_diagnostic_item(cx, ty, sym::Vec);
|
||||||
//check source object
|
//check source object
|
||||||
if let ExprKind::MethodCall(src_method, _, [drain_vec, drain_arg], _) = &arg.kind;
|
if let ExprKind::MethodCall(src_method, [drain_vec, drain_arg], _) = &arg.kind;
|
||||||
if src_method.ident.as_str() == "drain";
|
if src_method.ident.as_str() == "drain";
|
||||||
let src_ty = cx.typeck_results().expr_ty(drain_vec);
|
let src_ty = cx.typeck_results().expr_ty(drain_vec);
|
||||||
//check if actual src type is mutable for code suggestion
|
//check if actual src type is mutable for code suggestion
|
||||||
|
@ -28,7 +28,7 @@ fn is_method<'tcx>(cx: &LateContext<'tcx>, expr: &hir::Expr<'_>, method_name: Sy
|
|||||||
let closure_expr = peel_blocks(&body.value);
|
let closure_expr = peel_blocks(&body.value);
|
||||||
let arg_id = body.params[0].pat.hir_id;
|
let arg_id = body.params[0].pat.hir_id;
|
||||||
match closure_expr.kind {
|
match closure_expr.kind {
|
||||||
hir::ExprKind::MethodCall(hir::PathSegment { ident, .. }, _, args, _) => {
|
hir::ExprKind::MethodCall(hir::PathSegment { ident, .. }, args, _) => {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if ident.name == method_name;
|
if ident.name == method_name;
|
||||||
if let hir::ExprKind::Path(path) = &args[0].kind;
|
if let hir::ExprKind::Path(path) = &args[0].kind;
|
||||||
@ -118,7 +118,7 @@ pub(super) fn check<'tcx>(
|
|||||||
};
|
};
|
||||||
// closure ends with is_some() or is_ok()
|
// closure ends with is_some() or is_ok()
|
||||||
if let PatKind::Binding(_, filter_param_id, _, None) = filter_pat.kind;
|
if let PatKind::Binding(_, filter_param_id, _, None) = filter_pat.kind;
|
||||||
if let ExprKind::MethodCall(path, _, [filter_arg], _) = filter_body.value.kind;
|
if let ExprKind::MethodCall(path, [filter_arg], _) = filter_body.value.kind;
|
||||||
if let Some(opt_ty) = cx.typeck_results().expr_ty(filter_arg).ty_adt_def();
|
if let Some(opt_ty) = cx.typeck_results().expr_ty(filter_arg).ty_adt_def();
|
||||||
if let Some(is_result) = if cx.tcx.is_diagnostic_item(sym::Option, opt_ty.did) {
|
if let Some(is_result) = if cx.tcx.is_diagnostic_item(sym::Option, opt_ty.did) {
|
||||||
Some(false)
|
Some(false)
|
||||||
@ -135,7 +135,7 @@ pub(super) fn check<'tcx>(
|
|||||||
if let [map_param] = map_body.params;
|
if let [map_param] = map_body.params;
|
||||||
if let PatKind::Binding(_, map_param_id, map_param_ident, None) = map_param.pat.kind;
|
if let PatKind::Binding(_, map_param_id, map_param_ident, None) = map_param.pat.kind;
|
||||||
// closure ends with expect() or unwrap()
|
// closure ends with expect() or unwrap()
|
||||||
if let ExprKind::MethodCall(seg, _, [map_arg, ..], _) = map_body.value.kind;
|
if let ExprKind::MethodCall(seg, [map_arg, ..], _) = map_body.value.kind;
|
||||||
if matches!(seg.ident.name, sym::expect | sym::unwrap | sym::unwrap_or);
|
if matches!(seg.ident.name, sym::expect | sym::unwrap | sym::unwrap_or);
|
||||||
|
|
||||||
let eq_fallback = |a: &Expr<'_>, b: &Expr<'_>| {
|
let eq_fallback = |a: &Expr<'_>, b: &Expr<'_>| {
|
||||||
|
@ -2039,10 +2039,10 @@ impl_lint_pass!(Methods => [
|
|||||||
|
|
||||||
/// Extracts a method call name, args, and `Span` of the method name.
|
/// Extracts a method call name, args, and `Span` of the method name.
|
||||||
fn method_call<'tcx>(recv: &'tcx hir::Expr<'tcx>) -> Option<(&'tcx str, &'tcx [hir::Expr<'tcx>], Span)> {
|
fn method_call<'tcx>(recv: &'tcx hir::Expr<'tcx>) -> Option<(&'tcx str, &'tcx [hir::Expr<'tcx>], Span)> {
|
||||||
if let ExprKind::MethodCall(path, span, args, _) = recv.kind {
|
if let ExprKind::MethodCall(path, args, _) = recv.kind {
|
||||||
if !args.iter().any(|e| e.span.from_expansion()) {
|
if !args.iter().any(|e| e.span.from_expansion()) {
|
||||||
let name = path.ident.name.as_str();
|
let name = path.ident.name.as_str();
|
||||||
return Some((name, args, span));
|
return Some((name, args, path.ident.span));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None
|
None
|
||||||
@ -2060,14 +2060,15 @@ impl<'tcx> LateLintPass<'tcx> for Methods {
|
|||||||
hir::ExprKind::Call(func, args) => {
|
hir::ExprKind::Call(func, args) => {
|
||||||
from_iter_instead_of_collect::check(cx, expr, args, func);
|
from_iter_instead_of_collect::check(cx, expr, args, func);
|
||||||
},
|
},
|
||||||
hir::ExprKind::MethodCall(method_call, ref method_span, args, _) => {
|
hir::ExprKind::MethodCall(method_call, args, _) => {
|
||||||
or_fun_call::check(cx, expr, *method_span, method_call.ident.as_str(), args);
|
let method_span = method_call.ident.span;
|
||||||
expect_fun_call::check(cx, expr, *method_span, method_call.ident.as_str(), args);
|
or_fun_call::check(cx, expr, method_span, method_call.ident.as_str(), args);
|
||||||
|
expect_fun_call::check(cx, expr, method_span, method_call.ident.as_str(), args);
|
||||||
clone_on_copy::check(cx, expr, method_call.ident.name, args);
|
clone_on_copy::check(cx, expr, method_call.ident.name, args);
|
||||||
clone_on_ref_ptr::check(cx, expr, method_call.ident.name, args);
|
clone_on_ref_ptr::check(cx, expr, method_call.ident.name, args);
|
||||||
inefficient_to_string::check(cx, expr, method_call.ident.name, args);
|
inefficient_to_string::check(cx, expr, method_call.ident.name, args);
|
||||||
single_char_add_str::check(cx, expr, args);
|
single_char_add_str::check(cx, expr, args);
|
||||||
into_iter_on_ref::check(cx, expr, *method_span, method_call.ident.name, args);
|
into_iter_on_ref::check(cx, expr, method_span, method_call.ident.name, args);
|
||||||
single_char_pattern::check(cx, expr, method_call.ident.name, args);
|
single_char_pattern::check(cx, expr, method_call.ident.name, args);
|
||||||
unnecessary_to_owned::check(cx, expr, method_call.ident.name, args);
|
unnecessary_to_owned::check(cx, expr, method_call.ident.name, args);
|
||||||
},
|
},
|
||||||
|
@ -56,7 +56,7 @@ pub(super) fn check<'tcx>(
|
|||||||
let closure_expr = peel_blocks(&closure_body.value);
|
let closure_expr = peel_blocks(&closure_body.value);
|
||||||
|
|
||||||
match &closure_expr.kind {
|
match &closure_expr.kind {
|
||||||
hir::ExprKind::MethodCall(_, _, args, _) => {
|
hir::ExprKind::MethodCall(_, args, _) => {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if args.len() == 1;
|
if args.len() == 1;
|
||||||
if path_to_local_id(&args[0], closure_body.params[0].pat.hir_id);
|
if path_to_local_id(&args[0], closure_body.params[0].pat.hir_id);
|
||||||
|
@ -132,7 +132,7 @@ fn parse_iter_usage<'tcx>(
|
|||||||
) -> Option<IterUsage> {
|
) -> Option<IterUsage> {
|
||||||
let (kind, span) = match iter.next() {
|
let (kind, span) = match iter.next() {
|
||||||
Some((_, Node::Expr(e))) if e.span.ctxt() == ctxt => {
|
Some((_, Node::Expr(e))) if e.span.ctxt() == ctxt => {
|
||||||
let (name, args) = if let ExprKind::MethodCall(name, _, [_, args @ ..], _) = e.kind {
|
let (name, args) = if let ExprKind::MethodCall(name, [_, args @ ..], _) = e.kind {
|
||||||
(name, args)
|
(name, args)
|
||||||
} else {
|
} else {
|
||||||
return None;
|
return None;
|
||||||
@ -173,7 +173,7 @@ fn parse_iter_usage<'tcx>(
|
|||||||
} else {
|
} else {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let Some((_, Node::Expr(next_expr))) = iter.next();
|
if let Some((_, Node::Expr(next_expr))) = iter.next();
|
||||||
if let ExprKind::MethodCall(next_name, _, [_], _) = next_expr.kind;
|
if let ExprKind::MethodCall(next_name, [_], _) = next_expr.kind;
|
||||||
if next_name.ident.name == sym::next;
|
if next_name.ident.name == sym::next;
|
||||||
if next_expr.span.ctxt() == ctxt;
|
if next_expr.span.ctxt() == ctxt;
|
||||||
if let Some(next_id) = cx.typeck_results().type_dependent_def_id(next_expr.hir_id);
|
if let Some(next_id) = cx.typeck_results().type_dependent_def_id(next_expr.hir_id);
|
||||||
@ -217,7 +217,7 @@ fn parse_iter_usage<'tcx>(
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
_ if e.span.ctxt() != ctxt => (None, span),
|
_ if e.span.ctxt() != ctxt => (None, span),
|
||||||
ExprKind::MethodCall(name, _, [_], _)
|
ExprKind::MethodCall(name, [_], _)
|
||||||
if name.ident.name == sym::unwrap
|
if name.ident.name == sym::unwrap
|
||||||
&& cx
|
&& cx
|
||||||
.typeck_results()
|
.typeck_results()
|
||||||
@ -289,7 +289,7 @@ fn check_iter<'tcx>(
|
|||||||
) -> bool {
|
) -> bool {
|
||||||
match iter.next() {
|
match iter.next() {
|
||||||
Some((_, Node::Expr(e))) if e.span.ctxt() == ctxt => {
|
Some((_, Node::Expr(e))) if e.span.ctxt() == ctxt => {
|
||||||
let (name, args) = if let ExprKind::MethodCall(name, _, [_, args @ ..], _) = e.kind {
|
let (name, args) = if let ExprKind::MethodCall(name, [_, args @ ..], _) = e.kind {
|
||||||
(name, args)
|
(name, args)
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -45,7 +45,7 @@ pub fn check_for_loop_iter(
|
|||||||
if let Some(receiver_snippet) = snippet_opt(cx, receiver.span);
|
if let Some(receiver_snippet) = snippet_opt(cx, receiver.span);
|
||||||
then {
|
then {
|
||||||
let snippet = if_chain! {
|
let snippet = if_chain! {
|
||||||
if let ExprKind::MethodCall(maybe_iter_method_name, _, [collection], _) = receiver.kind;
|
if let ExprKind::MethodCall(maybe_iter_method_name, [collection], _) = receiver.kind;
|
||||||
if maybe_iter_method_name.ident.name == sym::iter;
|
if maybe_iter_method_name.ident.name == sym::iter;
|
||||||
|
|
||||||
if let Some(iterator_trait_id) = cx.tcx.get_diagnostic_item(sym::Iterator);
|
if let Some(iterator_trait_id) = cx.tcx.get_diagnostic_item(sym::Iterator);
|
||||||
@ -155,7 +155,7 @@ impl<'cx, 'tcx> Visitor<'tcx> for CloneOrCopyVisitor<'cx, 'tcx> {
|
|||||||
self.addr_of_exprs.push(parent);
|
self.addr_of_exprs.push(parent);
|
||||||
return;
|
return;
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(_, _, args, _) => {
|
ExprKind::MethodCall(_, args, _) => {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if args.iter().skip(1).all(|arg| !self.is_binding(arg));
|
if args.iter().skip(1).all(|arg| !self.is_binding(arg));
|
||||||
if let Some(method_def_id) = self.cx.typeck_results().type_dependent_def_id(parent.hir_id);
|
if let Some(method_def_id) = self.cx.typeck_results().type_dependent_def_id(parent.hir_id);
|
||||||
|
@ -313,7 +313,7 @@ fn get_callee_substs_and_args<'tcx>(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(_, _, args, _) = expr.kind;
|
if let ExprKind::MethodCall(_, args, _) = expr.kind;
|
||||||
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
||||||
then {
|
then {
|
||||||
let substs = cx.typeck_results().node_substs(expr.hir_id);
|
let substs = cx.typeck_results().node_substs(expr.hir_id);
|
||||||
|
@ -23,8 +23,8 @@ pub(super) fn check(cx: &LateContext<'_>, expr: &hir::Expr<'_>, call_name: &str,
|
|||||||
// allow the `as_ref` or `as_mut` if it is followed by another method call
|
// allow the `as_ref` or `as_mut` if it is followed by another method call
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let Some(parent) = get_parent_expr(cx, expr);
|
if let Some(parent) = get_parent_expr(cx, expr);
|
||||||
if let hir::ExprKind::MethodCall(_, ref span, _, _) = parent.kind;
|
if let hir::ExprKind::MethodCall(segment, ..) = parent.kind;
|
||||||
if span != &expr.span;
|
if segment.ident.span != expr.span;
|
||||||
then {
|
then {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@ pub(super) fn derefs_to_slice<'tcx>(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if let hir::ExprKind::MethodCall(path, _, [self_arg, ..], _) = &expr.kind {
|
if let hir::ExprKind::MethodCall(path, [self_arg, ..], _) = &expr.kind {
|
||||||
if path.ident.name == sym::iter && may_slice(cx, cx.typeck_results().expr_ty(self_arg)) {
|
if path.ident.name == sym::iter && may_slice(cx, cx.typeck_results().expr_ty(self_arg)) {
|
||||||
Some(self_arg)
|
Some(self_arg)
|
||||||
} else {
|
} else {
|
||||||
|
@ -86,7 +86,7 @@ fn min_max<'a>(cx: &LateContext<'_>, expr: &'a Expr<'a>) -> Option<(MinMax, Cons
|
|||||||
None
|
None
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(path, _, args, _) => {
|
ExprKind::MethodCall(path, args, _) => {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let [obj, _] = args;
|
if let [obj, _] = args;
|
||||||
if cx.typeck_results().expr_ty(obj).is_floating_point() || match_trait_method(cx, expr, &paths::ORD);
|
if cx.typeck_results().expr_ty(obj).is_floating_point() || match_trait_method(cx, expr, &paths::ORD);
|
||||||
|
@ -523,7 +523,7 @@ fn is_signum(cx: &LateContext<'_>, expr: &Expr<'_>) -> bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, [ref self_arg, ..], _) = expr.kind;
|
if let ExprKind::MethodCall(method_name, [ref self_arg, ..], _) = expr.kind;
|
||||||
if sym!(signum) == method_name.ident.name;
|
if sym!(signum) == method_name.ident.name;
|
||||||
// Check that the receiver of the signum() is a float (expressions[0] is the receiver of
|
// Check that the receiver of the signum() is a float (expressions[0] is the receiver of
|
||||||
// the method call)
|
// the method call)
|
||||||
|
@ -49,7 +49,7 @@ declare_lint_pass!(MutMutexLock => [MUT_MUTEX_LOCK]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for MutMutexLock {
|
impl<'tcx> LateLintPass<'tcx> for MutMutexLock {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, ex: &'tcx Expr<'tcx>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, ex: &'tcx Expr<'tcx>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, method_span, [self_arg, ..], _) = &ex.kind;
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &ex.kind;
|
||||||
if path.ident.name == sym!(lock);
|
if path.ident.name == sym!(lock);
|
||||||
let ty = cx.typeck_results().expr_ty(self_arg);
|
let ty = cx.typeck_results().expr_ty(self_arg);
|
||||||
if let ty::Ref(_, inner_ty, Mutability::Mut) = ty.kind();
|
if let ty::Ref(_, inner_ty, Mutability::Mut) = ty.kind();
|
||||||
@ -58,7 +58,7 @@ impl<'tcx> LateLintPass<'tcx> for MutMutexLock {
|
|||||||
span_lint_and_sugg(
|
span_lint_and_sugg(
|
||||||
cx,
|
cx,
|
||||||
MUT_MUTEX_LOCK,
|
MUT_MUTEX_LOCK,
|
||||||
*method_span,
|
path.ident.span,
|
||||||
"calling `&mut Mutex::lock` unnecessarily locks an exclusive (mutable) reference",
|
"calling `&mut Mutex::lock` unnecessarily locks an exclusive (mutable) reference",
|
||||||
"change this to",
|
"change this to",
|
||||||
"get_mut".to_owned(),
|
"get_mut".to_owned(),
|
||||||
|
@ -45,7 +45,7 @@ impl<'tcx> LateLintPass<'tcx> for UnnecessaryMutPassed {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(path, _, arguments, _) => {
|
ExprKind::MethodCall(path, arguments, _) => {
|
||||||
let def_id = cx.typeck_results().type_dependent_def_id(e.hir_id).unwrap();
|
let def_id = cx.typeck_results().type_dependent_def_id(e.hir_id).unwrap();
|
||||||
let substs = cx.typeck_results().node_substs(e.hir_id);
|
let substs = cx.typeck_results().node_substs(e.hir_id);
|
||||||
let method_type = cx.tcx.type_of(def_id).subst(cx.tcx, substs);
|
let method_type = cx.tcx.type_of(def_id).subst(cx.tcx, substs);
|
||||||
|
@ -56,12 +56,12 @@ impl<'tcx> LateLintPass<'tcx> for NeedlessForEach {
|
|||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// Check the method name is `for_each`.
|
// Check the method name is `for_each`.
|
||||||
if let ExprKind::MethodCall(method_name, _, [for_each_recv, for_each_arg], _) = expr.kind;
|
if let ExprKind::MethodCall(method_name, [for_each_recv, for_each_arg], _) = expr.kind;
|
||||||
if method_name.ident.name == Symbol::intern("for_each");
|
if method_name.ident.name == Symbol::intern("for_each");
|
||||||
// Check `for_each` is an associated function of `Iterator`.
|
// Check `for_each` is an associated function of `Iterator`.
|
||||||
if is_trait_method(cx, expr, sym::Iterator);
|
if is_trait_method(cx, expr, sym::Iterator);
|
||||||
// Checks the receiver of `for_each` is also a method call.
|
// Checks the receiver of `for_each` is also a method call.
|
||||||
if let ExprKind::MethodCall(_, _, [iter_recv], _) = for_each_recv.kind;
|
if let ExprKind::MethodCall(_, [iter_recv], _) = for_each_recv.kind;
|
||||||
// Skip the lint if the call chain is too long. e.g. `v.field.iter().for_each()` or
|
// Skip the lint if the call chain is too long. e.g. `v.field.iter().for_each()` or
|
||||||
// `v.foo().iter().for_each()` must be skipped.
|
// `v.foo().iter().for_each()` must be skipped.
|
||||||
if matches!(
|
if matches!(
|
||||||
|
@ -46,7 +46,7 @@ impl<'tcx> LateLintPass<'tcx> for OptionNeedlessDeref {
|
|||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if is_type_diagnostic_item(cx,outer_ty,sym::Option);
|
if is_type_diagnostic_item(cx,outer_ty,sym::Option);
|
||||||
if let ExprKind::MethodCall(path, _, [sub_expr], _) = expr.kind;
|
if let ExprKind::MethodCall(path, [sub_expr], _) = expr.kind;
|
||||||
let symbol = path.ident.as_str();
|
let symbol = path.ident.as_str();
|
||||||
if symbol == "as_deref" || symbol == "as_deref_mut";
|
if symbol == "as_deref" || symbol == "as_deref_mut";
|
||||||
if TyS::same_type( outer_ty, typeck.expr_ty(sub_expr) );
|
if TyS::same_type( outer_ty, typeck.expr_ty(sub_expr) );
|
||||||
|
@ -43,7 +43,7 @@ declare_lint_pass!(NonOctalUnixPermissions => [NON_OCTAL_UNIX_PERMISSIONS]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for NonOctalUnixPermissions {
|
impl<'tcx> LateLintPass<'tcx> for NonOctalUnixPermissions {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) {
|
||||||
match &expr.kind {
|
match &expr.kind {
|
||||||
ExprKind::MethodCall(path, _, [func, param], _) => {
|
ExprKind::MethodCall(path, [func, param], _) => {
|
||||||
let obj_ty = cx.typeck_results().expr_ty(func).peel_refs();
|
let obj_ty = cx.typeck_results().expr_ty(func).peel_refs();
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
|
@ -32,7 +32,7 @@ declare_lint_pass!(OpenOptions => [NONSENSICAL_OPEN_OPTIONS]);
|
|||||||
|
|
||||||
impl<'tcx> LateLintPass<'tcx> for OpenOptions {
|
impl<'tcx> LateLintPass<'tcx> for OpenOptions {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, e: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, e: &'tcx Expr<'_>) {
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, ..], _) = &e.kind {
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &e.kind {
|
||||||
let obj_ty = cx.typeck_results().expr_ty(self_arg).peel_refs();
|
let obj_ty = cx.typeck_results().expr_ty(self_arg).peel_refs();
|
||||||
if path.ident.name == sym!(open) && match_type(cx, obj_ty, &paths::OPEN_OPTIONS) {
|
if path.ident.name == sym!(open) && match_type(cx, obj_ty, &paths::OPEN_OPTIONS) {
|
||||||
let mut options = Vec::new();
|
let mut options = Vec::new();
|
||||||
@ -60,7 +60,7 @@ enum OpenOption {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn get_open_options(cx: &LateContext<'_>, argument: &Expr<'_>, options: &mut Vec<(OpenOption, Argument)>) {
|
fn get_open_options(cx: &LateContext<'_>, argument: &Expr<'_>, options: &mut Vec<(OpenOption, Argument)>) {
|
||||||
if let ExprKind::MethodCall(path, _, arguments, _) = argument.kind {
|
if let ExprKind::MethodCall(path, arguments, _) = argument.kind {
|
||||||
let obj_ty = cx.typeck_results().expr_ty(&arguments[0]).peel_refs();
|
let obj_ty = cx.typeck_results().expr_ty(&arguments[0]).peel_refs();
|
||||||
|
|
||||||
// Only proceed if this is a call on some object of type std::fs::OpenOptions
|
// Only proceed if this is a call on some object of type std::fs::OpenOptions
|
||||||
|
@ -68,7 +68,7 @@ declare_lint_pass!(OptionIfLetElse => [OPTION_IF_LET_ELSE]);
|
|||||||
|
|
||||||
/// Returns true iff the given expression is the result of calling `Result::ok`
|
/// Returns true iff the given expression is the result of calling `Result::ok`
|
||||||
fn is_result_ok(cx: &LateContext<'_>, expr: &'_ Expr<'_>) -> bool {
|
fn is_result_ok(cx: &LateContext<'_>, expr: &'_ Expr<'_>) -> bool {
|
||||||
if let ExprKind::MethodCall(path, _, &[ref receiver], _) = &expr.kind {
|
if let ExprKind::MethodCall(path, &[ref receiver], _) = &expr.kind {
|
||||||
path.ident.name.as_str() == "ok"
|
path.ident.name.as_str() == "ok"
|
||||||
&& is_type_diagnostic_item(cx, cx.typeck_results().expr_ty(receiver), sym::Result)
|
&& is_type_diagnostic_item(cx, cx.typeck_results().expr_ty(receiver), sym::Result)
|
||||||
} else {
|
} else {
|
||||||
|
@ -46,7 +46,7 @@ declare_lint_pass!(PathBufPushOverwrite => [PATH_BUF_PUSH_OVERWRITE]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for PathBufPushOverwrite {
|
impl<'tcx> LateLintPass<'tcx> for PathBufPushOverwrite {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = expr.kind;
|
if let ExprKind::MethodCall(path, args, _) = expr.kind;
|
||||||
if path.ident.name == sym!(push);
|
if path.ident.name == sym!(push);
|
||||||
if args.len() == 2;
|
if args.len() == 2;
|
||||||
if is_type_diagnostic_item(cx, cx.typeck_results().expr_ty(&args[0]).peel_refs(), sym::PathBuf);
|
if is_type_diagnostic_item(cx, cx.typeck_results().expr_ty(&args[0]).peel_refs(), sym::PathBuf);
|
||||||
|
@ -93,7 +93,7 @@ fn expr_as_ptr_offset_call<'tcx>(
|
|||||||
cx: &LateContext<'tcx>,
|
cx: &LateContext<'tcx>,
|
||||||
expr: &'tcx Expr<'_>,
|
expr: &'tcx Expr<'_>,
|
||||||
) -> Option<(&'tcx Expr<'tcx>, &'tcx Expr<'tcx>, Method)> {
|
) -> Option<(&'tcx Expr<'tcx>, &'tcx Expr<'tcx>, Method)> {
|
||||||
if let ExprKind::MethodCall(path_segment, _, [arg_0, arg_1, ..], _) = &expr.kind {
|
if let ExprKind::MethodCall(path_segment, [arg_0, arg_1, ..], _) = &expr.kind {
|
||||||
if is_expr_ty_raw_ptr(cx, arg_0) {
|
if is_expr_ty_raw_ptr(cx, arg_0) {
|
||||||
if path_segment.ident.name == sym::offset {
|
if path_segment.ident.name == sym::offset {
|
||||||
return Some((arg_0, arg_1, Method::Offset));
|
return Some((arg_0, arg_1, Method::Offset));
|
||||||
|
@ -58,7 +58,7 @@ impl QuestionMark {
|
|||||||
fn check_is_none_or_err_and_early_return(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
fn check_is_none_or_err_and_early_return(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let Some(higher::If { cond, then, r#else }) = higher::If::hir(expr);
|
if let Some(higher::If { cond, then, r#else }) = higher::If::hir(expr);
|
||||||
if let ExprKind::MethodCall(segment, _, args, _) = &cond.kind;
|
if let ExprKind::MethodCall(segment, args, _) = &cond.kind;
|
||||||
if let Some(subject) = args.get(0);
|
if let Some(subject) = args.get(0);
|
||||||
if (Self::option_check_and_early_return(cx, subject, then) && segment.ident.name == sym!(is_none)) ||
|
if (Self::option_check_and_early_return(cx, subject, then) && segment.ident.name == sym!(is_none)) ||
|
||||||
(Self::result_check_and_early_return(cx, subject, then) && segment.ident.name == sym!(is_err));
|
(Self::result_check_and_early_return(cx, subject, then) && segment.ident.name == sym!(is_err));
|
||||||
|
@ -190,7 +190,7 @@ impl_lint_pass!(Ranges => [
|
|||||||
impl<'tcx> LateLintPass<'tcx> for Ranges {
|
impl<'tcx> LateLintPass<'tcx> for Ranges {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
ExprKind::MethodCall(path, _, args, _) => {
|
ExprKind::MethodCall(path, args, _) => {
|
||||||
check_range_zip_with_len(cx, path, args, expr.span);
|
check_range_zip_with_len(cx, path, args, expr.span);
|
||||||
},
|
},
|
||||||
ExprKind::Binary(ref op, l, r) => {
|
ExprKind::Binary(ref op, l, r) => {
|
||||||
@ -331,13 +331,13 @@ fn check_range_zip_with_len(cx: &LateContext<'_>, path: &PathSegment<'_>, args:
|
|||||||
if path.ident.as_str() == "zip";
|
if path.ident.as_str() == "zip";
|
||||||
if let [iter, zip_arg] = args;
|
if let [iter, zip_arg] = args;
|
||||||
// `.iter()` call
|
// `.iter()` call
|
||||||
if let ExprKind::MethodCall(iter_path, _, iter_args, _) = iter.kind;
|
if let ExprKind::MethodCall(iter_path, iter_args, _) = iter.kind;
|
||||||
if iter_path.ident.name == sym::iter;
|
if iter_path.ident.name == sym::iter;
|
||||||
// range expression in `.zip()` call: `0..x.len()`
|
// range expression in `.zip()` call: `0..x.len()`
|
||||||
if let Some(higher::Range { start: Some(start), end: Some(end), .. }) = higher::Range::hir(zip_arg);
|
if let Some(higher::Range { start: Some(start), end: Some(end), .. }) = higher::Range::hir(zip_arg);
|
||||||
if is_integer_const(cx, start, 0);
|
if is_integer_const(cx, start, 0);
|
||||||
// `.len()` call
|
// `.len()` call
|
||||||
if let ExprKind::MethodCall(len_path, _, len_args, _) = end.kind;
|
if let ExprKind::MethodCall(len_path, len_args, _) = end.kind;
|
||||||
if len_path.ident.name == sym::len && len_args.len() == 1;
|
if len_path.ident.name == sym::len && len_args.len() == 1;
|
||||||
// `.iter()` and `.len()` called on same `Path`
|
// `.iter()` and `.len()` called on same `Path`
|
||||||
if let ExprKind::Path(QPath::Resolved(_, iter_path)) = iter_args[0].kind;
|
if let ExprKind::Path(QPath::Resolved(_, iter_path)) = iter_args[0].kind;
|
||||||
|
@ -46,7 +46,7 @@ declare_lint_pass!(RepeatOnce => [REPEAT_ONCE]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for RepeatOnce {
|
impl<'tcx> LateLintPass<'tcx> for RepeatOnce {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, [receiver, count], _) = &expr.kind;
|
if let ExprKind::MethodCall(path, [receiver, count], _) = &expr.kind;
|
||||||
if path.ident.name == sym!(repeat);
|
if path.ident.name == sym!(repeat);
|
||||||
if constant_context(cx, cx.typeck_results()).expr(count) == Some(Constant::Int(1));
|
if constant_context(cx, cx.typeck_results()).expr(count) == Some(Constant::Int(1));
|
||||||
if !receiver.span.from_expansion();
|
if !receiver.span.from_expansion();
|
||||||
|
@ -108,7 +108,7 @@ fn get_pointee_ty_and_count_expr<'tcx>(
|
|||||||
};
|
};
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// Find calls to copy_{from,to}{,_nonoverlapping} and write_bytes methods
|
// Find calls to copy_{from,to}{,_nonoverlapping} and write_bytes methods
|
||||||
if let ExprKind::MethodCall(method_path, _, [ptr_self, .., count], _) = expr.kind;
|
if let ExprKind::MethodCall(method_path, [ptr_self, .., count], _) = expr.kind;
|
||||||
let method_ident = method_path.ident.as_str();
|
let method_ident = method_path.ident.as_str();
|
||||||
if METHODS.iter().any(|m| *m == &*method_ident);
|
if METHODS.iter().any(|m| *m == &*method_ident);
|
||||||
|
|
||||||
|
@ -197,7 +197,7 @@ impl<'a, 'tcx> VectorInitializationVisitor<'a, 'tcx> {
|
|||||||
fn search_slow_extend_filling(&mut self, expr: &'tcx Expr<'_>) {
|
fn search_slow_extend_filling(&mut self, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if self.initialization_found;
|
if self.initialization_found;
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, extend_arg], _) = expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, extend_arg], _) = expr.kind;
|
||||||
if path_to_local_id(self_arg, self.vec_alloc.local_id);
|
if path_to_local_id(self_arg, self.vec_alloc.local_id);
|
||||||
if path.ident.name == sym!(extend);
|
if path.ident.name == sym!(extend);
|
||||||
if self.is_repeat_take(extend_arg);
|
if self.is_repeat_take(extend_arg);
|
||||||
@ -212,7 +212,7 @@ impl<'a, 'tcx> VectorInitializationVisitor<'a, 'tcx> {
|
|||||||
fn search_slow_resize_filling(&mut self, expr: &'tcx Expr<'_>) {
|
fn search_slow_resize_filling(&mut self, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if self.initialization_found;
|
if self.initialization_found;
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, len_arg, fill_arg], _) = expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, len_arg, fill_arg], _) = expr.kind;
|
||||||
if path_to_local_id(self_arg, self.vec_alloc.local_id);
|
if path_to_local_id(self_arg, self.vec_alloc.local_id);
|
||||||
if path.ident.name == sym!(resize);
|
if path.ident.name == sym!(resize);
|
||||||
|
|
||||||
@ -232,7 +232,7 @@ impl<'a, 'tcx> VectorInitializationVisitor<'a, 'tcx> {
|
|||||||
/// Returns `true` if give expression is `repeat(0).take(...)`
|
/// Returns `true` if give expression is `repeat(0).take(...)`
|
||||||
fn is_repeat_take(&self, expr: &Expr<'_>) -> bool {
|
fn is_repeat_take(&self, expr: &Expr<'_>) -> bool {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(take_path, _, take_args, _) = expr.kind;
|
if let ExprKind::MethodCall(take_path, take_args, _) = expr.kind;
|
||||||
if take_path.ident.name == sym!(take);
|
if take_path.ident.name == sym!(take);
|
||||||
|
|
||||||
// Check that take is applied to `repeat(0)`
|
// Check that take is applied to `repeat(0)`
|
||||||
|
@ -87,7 +87,7 @@ struct LintDetection {
|
|||||||
|
|
||||||
fn detect_stable_sort_primitive(cx: &LateContext<'_>, expr: &Expr<'_>) -> Option<LintDetection> {
|
fn detect_stable_sort_primitive(cx: &LateContext<'_>, expr: &Expr<'_>) -> Option<LintDetection> {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, args, _) = &expr.kind;
|
if let ExprKind::MethodCall(method_name, args, _) = &expr.kind;
|
||||||
if let Some(slice) = &args.get(0);
|
if let Some(slice) = &args.get(0);
|
||||||
if let Some(method) = SortingKind::from_stable_name(method_name.ident.name.as_str());
|
if let Some(method) = SortingKind::from_stable_name(method_name.ident.name.as_str());
|
||||||
if let Some(slice_type) = is_slice_of_primitives(cx, slice);
|
if let Some(slice_type) = is_slice_of_primitives(cx, slice);
|
||||||
|
@ -282,7 +282,7 @@ impl<'tcx> LateLintPass<'tcx> for StringLitAsBytes {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = &e.kind;
|
if let ExprKind::MethodCall(path, args, _) = &e.kind;
|
||||||
if path.ident.name == sym!(as_bytes);
|
if path.ident.name == sym!(as_bytes);
|
||||||
if let ExprKind::Lit(lit) = &args[0].kind;
|
if let ExprKind::Lit(lit) = &args[0].kind;
|
||||||
if let LitKind::Str(lit_content, _) = &lit.node;
|
if let LitKind::Str(lit_content, _) = &lit.node;
|
||||||
@ -324,9 +324,9 @@ impl<'tcx> LateLintPass<'tcx> for StringLitAsBytes {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, [recv], _) = &e.kind;
|
if let ExprKind::MethodCall(path, [recv], _) = &e.kind;
|
||||||
if path.ident.name == sym!(into_bytes);
|
if path.ident.name == sym!(into_bytes);
|
||||||
if let ExprKind::MethodCall(path, _, [recv], _) = &recv.kind;
|
if let ExprKind::MethodCall(path, [recv], _) = &recv.kind;
|
||||||
if matches!(path.ident.name.as_str(), "to_owned" | "to_string");
|
if matches!(path.ident.name.as_str(), "to_owned" | "to_string");
|
||||||
if let ExprKind::Lit(lit) = &recv.kind;
|
if let ExprKind::Lit(lit) = &recv.kind;
|
||||||
if let LitKind::Str(lit_content, _) = &lit.node;
|
if let LitKind::Str(lit_content, _) = &lit.node;
|
||||||
@ -384,7 +384,7 @@ declare_lint_pass!(StrToString => [STR_TO_STRING]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for StrToString {
|
impl<'tcx> LateLintPass<'tcx> for StrToString {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, ..], _) = &expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &expr.kind;
|
||||||
if path.ident.name == sym!(to_string);
|
if path.ident.name == sym!(to_string);
|
||||||
let ty = cx.typeck_results().expr_ty(self_arg);
|
let ty = cx.typeck_results().expr_ty(self_arg);
|
||||||
if let ty::Ref(_, ty, ..) = ty.kind();
|
if let ty::Ref(_, ty, ..) = ty.kind();
|
||||||
@ -434,7 +434,7 @@ declare_lint_pass!(StringToString => [STRING_TO_STRING]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for StringToString {
|
impl<'tcx> LateLintPass<'tcx> for StringToString {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, ..], _) = &expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &expr.kind;
|
||||||
if path.ident.name == sym!(to_string);
|
if path.ident.name == sym!(to_string);
|
||||||
let ty = cx.typeck_results().expr_ty(self_arg);
|
let ty = cx.typeck_results().expr_ty(self_arg);
|
||||||
if is_type_diagnostic_item(cx, ty, sym::String);
|
if is_type_diagnostic_item(cx, ty, sym::String);
|
||||||
|
@ -47,7 +47,7 @@ impl<'tcx> LateLintPass<'tcx> for StrlenOnCStrings {
|
|||||||
if let ExprKind::Path(path) = &func.kind;
|
if let ExprKind::Path(path) = &func.kind;
|
||||||
if let Some(did) = cx.qpath_res(path, func.hir_id).opt_def_id();
|
if let Some(did) = cx.qpath_res(path, func.hir_id).opt_def_id();
|
||||||
if match_libc_symbol(cx, did, "strlen");
|
if match_libc_symbol(cx, did, "strlen");
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg], _) = recv.kind;
|
if let ExprKind::MethodCall(path, [self_arg], _) = recv.kind;
|
||||||
if !recv.span.from_expansion();
|
if !recv.span.from_expansion();
|
||||||
if path.ident.name == sym::as_ptr;
|
if path.ident.name == sym::as_ptr;
|
||||||
then {
|
then {
|
||||||
|
@ -39,12 +39,12 @@ declare_lint_pass!(ToDigitIsSome => [TO_DIGIT_IS_SOME]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for ToDigitIsSome {
|
impl<'tcx> LateLintPass<'tcx> for ToDigitIsSome {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx hir::Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx hir::Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let hir::ExprKind::MethodCall(is_some_path, _, is_some_args, _) = &expr.kind;
|
if let hir::ExprKind::MethodCall(is_some_path, is_some_args, _) = &expr.kind;
|
||||||
if is_some_path.ident.name.as_str() == "is_some";
|
if is_some_path.ident.name.as_str() == "is_some";
|
||||||
if let [to_digit_expr] = &**is_some_args;
|
if let [to_digit_expr] = &**is_some_args;
|
||||||
then {
|
then {
|
||||||
let match_result = match &to_digit_expr.kind {
|
let match_result = match &to_digit_expr.kind {
|
||||||
hir::ExprKind::MethodCall(to_digits_path, _, to_digit_args, _) => {
|
hir::ExprKind::MethodCall(to_digits_path, to_digit_args, _) => {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let [char_arg, radix_arg] = &**to_digit_args;
|
if let [char_arg, radix_arg] = &**to_digit_args;
|
||||||
if to_digits_path.ident.name.as_str() == "to_digit";
|
if to_digits_path.ident.name.as_str() == "to_digit";
|
||||||
|
@ -93,7 +93,7 @@ impl LateLintPass<'_> for ToStringInDisplay {
|
|||||||
if_chain! {
|
if_chain! {
|
||||||
if self.in_display_impl;
|
if self.in_display_impl;
|
||||||
if let Some(self_hir_id) = self.self_hir_id;
|
if let Some(self_hir_id) = self.self_hir_id;
|
||||||
if let ExprKind::MethodCall(path, _, [ref self_arg, ..], _) = expr.kind;
|
if let ExprKind::MethodCall(path, [ref self_arg, ..], _) = expr.kind;
|
||||||
if path.ident.name == sym!(to_string);
|
if path.ident.name == sym!(to_string);
|
||||||
if let Some(expr_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
if let Some(expr_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
||||||
if is_diag_trait_item(cx, expr_def_id, sym::ToString);
|
if is_diag_trait_item(cx, expr_def_id, sym::ToString);
|
||||||
|
@ -177,7 +177,7 @@ fn extract_init_or_reserve_target<'tcx>(cx: &LateContext<'tcx>, stmt: &'tcx Stmt
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(path, _, [self_expr, _], _) if is_reserve(cx, path, self_expr) => {
|
ExprKind::MethodCall(path, [self_expr, _], _) if is_reserve(cx, path, self_expr) => {
|
||||||
return Some(TargetVec {
|
return Some(TargetVec {
|
||||||
location: VecLocation::Expr(self_expr),
|
location: VecLocation::Expr(self_expr),
|
||||||
init_kind: None,
|
init_kind: None,
|
||||||
@ -211,7 +211,7 @@ fn extract_set_len_self<'tcx>(cx: &LateContext<'_>, expr: &'tcx Expr<'_>) -> Opt
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
ExprKind::MethodCall(path, _, [self_expr, _], _) => {
|
ExprKind::MethodCall(path, [self_expr, _], _) => {
|
||||||
let self_type = cx.typeck_results().expr_ty(self_expr).peel_refs();
|
let self_type = cx.typeck_results().expr_ty(self_expr).peel_refs();
|
||||||
if is_type_diagnostic_item(cx, self_type, sym::Vec) && path.ident.name.as_str() == "set_len" {
|
if is_type_diagnostic_item(cx, self_type, sym::Vec) && path.ident.name.as_str() == "set_len" {
|
||||||
Some((self_expr, expr.span))
|
Some((self_expr, expr.span))
|
||||||
|
@ -49,7 +49,7 @@ declare_lint_pass!(UnitHash => [UNIT_HASH]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for UnitHash {
|
impl<'tcx> LateLintPass<'tcx> for UnitHash {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(name_ident, _, args, _) = &expr.kind;
|
if let ExprKind::MethodCall(name_ident, args, _) = &expr.kind;
|
||||||
if name_ident.ident.name == sym::hash;
|
if name_ident.ident.name == sym::hash;
|
||||||
if let [recv, state_param] = args;
|
if let [recv, state_param] = args;
|
||||||
if cx.typeck_results().expr_ty(recv).is_unit();
|
if cx.typeck_results().expr_ty(recv).is_unit();
|
||||||
|
@ -142,7 +142,7 @@ fn check_arg<'tcx>(cx: &LateContext<'tcx>, arg: &'tcx Expr<'tcx>) -> Option<(Spa
|
|||||||
|
|
||||||
impl<'tcx> LateLintPass<'tcx> for UnitReturnExpectingOrd {
|
impl<'tcx> LateLintPass<'tcx> for UnitReturnExpectingOrd {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) {
|
||||||
if let ExprKind::MethodCall(_, _, args, _) = expr.kind {
|
if let ExprKind::MethodCall(_, args, _) = expr.kind {
|
||||||
let arg_indices = get_args_to_check(cx, expr);
|
let arg_indices = get_args_to_check(cx, expr);
|
||||||
for (i, trait_name) in arg_indices {
|
for (i, trait_name) in arg_indices {
|
||||||
if i < args.len() {
|
if i < args.len() {
|
||||||
|
@ -30,7 +30,7 @@ pub(super) fn check(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
match expr.kind {
|
match expr.kind {
|
||||||
ExprKind::Call(_, args) | ExprKind::MethodCall(_, _, args, _) => {
|
ExprKind::Call(_, args) | ExprKind::MethodCall(_, args, _) => {
|
||||||
let args_to_recover = args
|
let args_to_recover = args
|
||||||
.iter()
|
.iter()
|
||||||
.filter(|arg| {
|
.filter(|arg| {
|
||||||
|
@ -93,10 +93,7 @@ fn mirrored_exprs(
|
|||||||
// The two exprs are method calls.
|
// The two exprs are method calls.
|
||||||
// Check to see that the function is the same and the arguments are mirrored
|
// Check to see that the function is the same and the arguments are mirrored
|
||||||
// This is enough because the receiver of the method is listed in the arguments
|
// This is enough because the receiver of the method is listed in the arguments
|
||||||
(
|
(ExprKind::MethodCall(left_segment, left_args, _), ExprKind::MethodCall(right_segment, right_args, _)) => {
|
||||||
ExprKind::MethodCall(left_segment, _, left_args, _),
|
|
||||||
ExprKind::MethodCall(right_segment, _, right_args, _),
|
|
||||||
) => {
|
|
||||||
left_segment.ident == right_segment.ident
|
left_segment.ident == right_segment.ident
|
||||||
&& iter::zip(*left_args, *right_args)
|
&& iter::zip(*left_args, *right_args)
|
||||||
.all(|(left, right)| mirrored_exprs(cx, left, a_ident, right, b_ident))
|
.all(|(left, right)| mirrored_exprs(cx, left, a_ident, right, b_ident))
|
||||||
@ -165,7 +162,7 @@ fn mirrored_exprs(
|
|||||||
|
|
||||||
fn detect_lint(cx: &LateContext<'_>, expr: &Expr<'_>) -> Option<LintTrigger> {
|
fn detect_lint(cx: &LateContext<'_>, expr: &Expr<'_>) -> Option<LintTrigger> {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(name_ident, _, args, _) = &expr.kind;
|
if let ExprKind::MethodCall(name_ident, args, _) = &expr.kind;
|
||||||
if let name = name_ident.ident.name.to_ident_string();
|
if let name = name_ident.ident.name.to_ident_string();
|
||||||
if name == "sort_by" || name == "sort_unstable_by";
|
if name == "sort_by" || name == "sort_unstable_by";
|
||||||
if let [vec, Expr { kind: ExprKind::Closure(_, _, closure_body_id, _, _), .. }] = args;
|
if let [vec, Expr { kind: ExprKind::Closure(_, _, closure_body_id, _, _), .. }] = args;
|
||||||
@ -175,7 +172,7 @@ fn detect_lint(cx: &LateContext<'_>, expr: &Expr<'_>) -> Option<LintTrigger> {
|
|||||||
Param { pat: Pat { kind: PatKind::Binding(_, _, left_ident, _), .. }, ..},
|
Param { pat: Pat { kind: PatKind::Binding(_, _, left_ident, _), .. }, ..},
|
||||||
Param { pat: Pat { kind: PatKind::Binding(_, _, right_ident, _), .. }, .. }
|
Param { pat: Pat { kind: PatKind::Binding(_, _, right_ident, _), .. }, .. }
|
||||||
] = &closure_body.params;
|
] = &closure_body.params;
|
||||||
if let ExprKind::MethodCall(method_path, _, [ref left_expr, ref right_expr], _) = &closure_body.value.kind;
|
if let ExprKind::MethodCall(method_path, [ref left_expr, ref right_expr], _) = &closure_body.value.kind;
|
||||||
if method_path.ident.name == sym::cmp;
|
if method_path.ident.name == sym::cmp;
|
||||||
then {
|
then {
|
||||||
let (closure_body, closure_arg, reverse) = if mirrored_exprs(
|
let (closure_body, closure_arg, reverse) = if mirrored_exprs(
|
||||||
|
@ -64,7 +64,7 @@ impl<'tcx> LateLintPass<'tcx> for UnusedIoAmount {
|
|||||||
check_map_error(cx, res, expr);
|
check_map_error(cx, res, expr);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
hir::ExprKind::MethodCall(path, _, [ref arg_0, ..], _) => match path.ident.as_str() {
|
hir::ExprKind::MethodCall(path, [ref arg_0, ..], _) => match path.ident.as_str() {
|
||||||
"expect" | "unwrap" | "unwrap_or" | "unwrap_or_else" => {
|
"expect" | "unwrap" | "unwrap_or" | "unwrap_or_else" => {
|
||||||
check_map_error(cx, arg_0, expr);
|
check_map_error(cx, arg_0, expr);
|
||||||
},
|
},
|
||||||
@ -94,7 +94,7 @@ fn try_remove_await<'a>(expr: &'a hir::Expr<'a>) -> Option<&hir::Expr<'a>> {
|
|||||||
|
|
||||||
fn check_map_error(cx: &LateContext<'_>, call: &hir::Expr<'_>, expr: &hir::Expr<'_>) {
|
fn check_map_error(cx: &LateContext<'_>, call: &hir::Expr<'_>, expr: &hir::Expr<'_>) {
|
||||||
let mut call = call;
|
let mut call = call;
|
||||||
while let hir::ExprKind::MethodCall(path, _, args, _) = call.kind {
|
while let hir::ExprKind::MethodCall(path, args, _) = call.kind {
|
||||||
if matches!(path.ident.as_str(), "or" | "or_else" | "ok") {
|
if matches!(path.ident.as_str(), "or" | "or_else" | "ok") {
|
||||||
call = &args[0];
|
call = &args[0];
|
||||||
} else {
|
} else {
|
||||||
@ -110,7 +110,7 @@ fn check_map_error(cx: &LateContext<'_>, call: &hir::Expr<'_>, expr: &hir::Expr<
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn check_method_call(cx: &LateContext<'_>, call: &hir::Expr<'_>, expr: &hir::Expr<'_>, is_await: bool) {
|
fn check_method_call(cx: &LateContext<'_>, call: &hir::Expr<'_>, expr: &hir::Expr<'_>, is_await: bool) {
|
||||||
if let hir::ExprKind::MethodCall(path, _, _, _) = call.kind {
|
if let hir::ExprKind::MethodCall(path, _, _) = call.kind {
|
||||||
let symbol = path.ident.as_str();
|
let symbol = path.ident.as_str();
|
||||||
let read_trait = if is_await {
|
let read_trait = if is_await {
|
||||||
match_trait_method(cx, call, &paths::FUTURES_IO_ASYNCREADEXT)
|
match_trait_method(cx, call, &paths::FUTURES_IO_ASYNCREADEXT)
|
||||||
|
@ -154,7 +154,7 @@ fn collect_unwrap_info<'tcx>(
|
|||||||
return collect_unwrap_info(cx, if_expr, expr, branch, !invert, false);
|
return collect_unwrap_info(cx, if_expr, expr, branch, !invert, false);
|
||||||
} else {
|
} else {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, args, _) = &expr.kind;
|
if let ExprKind::MethodCall(method_name, args, _) = &expr.kind;
|
||||||
if let Some(local_id) = path_to_local(&args[0]);
|
if let Some(local_id) = path_to_local(&args[0]);
|
||||||
let ty = cx.typeck_results().expr_ty(&args[0]);
|
let ty = cx.typeck_results().expr_ty(&args[0]);
|
||||||
let name = method_name.ident.as_str();
|
let name = method_name.ident.as_str();
|
||||||
@ -231,7 +231,7 @@ impl<'a, 'tcx> Visitor<'tcx> for UnwrappableVariablesVisitor<'a, 'tcx> {
|
|||||||
} else {
|
} else {
|
||||||
// find `unwrap[_err]()` calls:
|
// find `unwrap[_err]()` calls:
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, [self_arg, ..], _) = expr.kind;
|
if let ExprKind::MethodCall(method_name, [self_arg, ..], _) = expr.kind;
|
||||||
if let Some(id) = path_to_local(self_arg);
|
if let Some(id) = path_to_local(self_arg);
|
||||||
if [sym::unwrap, sym::expect, sym!(unwrap_err)].contains(&method_name.ident.name);
|
if [sym::unwrap, sym::expect, sym!(unwrap_err)].contains(&method_name.ident.name);
|
||||||
let call_to_unwrap = [sym::unwrap, sym::expect].contains(&method_name.ident.name);
|
let call_to_unwrap = [sym::unwrap, sym::expect].contains(&method_name.ident.name);
|
||||||
|
@ -402,9 +402,9 @@ impl<'a, 'tcx> PrintVisitor<'a, 'tcx> {
|
|||||||
self.expr(func);
|
self.expr(func);
|
||||||
self.slice(args, |e| self.expr(e));
|
self.slice(args, |e| self.expr(e));
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(method_name, _, args, _) => {
|
ExprKind::MethodCall(method_name, args, _) => {
|
||||||
bind!(self, method_name, args);
|
bind!(self, method_name, args);
|
||||||
kind!("MethodCall({method_name}, _, {args}, _)");
|
kind!("MethodCall({method_name}, {args}, _)");
|
||||||
self.ident(field!(method_name.ident));
|
self.ident(field!(method_name.ident));
|
||||||
self.slice(args, |e| self.expr(e));
|
self.slice(args, |e| self.expr(e));
|
||||||
},
|
},
|
||||||
|
@ -149,7 +149,7 @@ fn print_expr(cx: &LateContext<'_>, expr: &hir::Expr<'_>, indent: usize) {
|
|||||||
}
|
}
|
||||||
print_expr(cx, init, indent + 1);
|
print_expr(cx, init, indent + 1);
|
||||||
},
|
},
|
||||||
hir::ExprKind::MethodCall(path, _, args, _) => {
|
hir::ExprKind::MethodCall(path, args, _) => {
|
||||||
println!("{}MethodCall", ind);
|
println!("{}MethodCall", ind);
|
||||||
println!("{}method name: {}", ind, path.ident.name);
|
println!("{}method name: {}", ind, path.ident.name);
|
||||||
for arg in args {
|
for arg in args {
|
||||||
|
@ -583,7 +583,7 @@ impl<'tcx> LateLintPass<'tcx> for CompilerLintFunctions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, ..], _) = &expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, ..], _) = &expr.kind;
|
||||||
let fn_name = path.ident;
|
let fn_name = path.ident;
|
||||||
if let Some(sugg) = self.map.get(&*fn_name.as_str());
|
if let Some(sugg) = self.map.get(&*fn_name.as_str());
|
||||||
let ty = cx.typeck_results().expr_ty(self_arg).peel_refs();
|
let ty = cx.typeck_results().expr_ty(self_arg).peel_refs();
|
||||||
@ -665,7 +665,7 @@ impl<'tcx> LateLintPass<'tcx> for CollapsibleCalls {
|
|||||||
if let ExprKind::Closure(_, _, body_id, _, _) = &and_then_args[4].kind;
|
if let ExprKind::Closure(_, _, body_id, _, _) = &and_then_args[4].kind;
|
||||||
let body = cx.tcx.hir().body(*body_id);
|
let body = cx.tcx.hir().body(*body_id);
|
||||||
let only_expr = peel_blocks_with_stmt(&body.value);
|
let only_expr = peel_blocks_with_stmt(&body.value);
|
||||||
if let ExprKind::MethodCall(ps, _, span_call_args, _) = &only_expr.kind;
|
if let ExprKind::MethodCall(ps, span_call_args, _) = &only_expr.kind;
|
||||||
then {
|
then {
|
||||||
let and_then_snippets = get_and_then_snippets(cx, and_then_args);
|
let and_then_snippets = get_and_then_snippets(cx, and_then_args);
|
||||||
let mut sle = SpanlessEq::new(cx).deny_side_effects();
|
let mut sle = SpanlessEq::new(cx).deny_side_effects();
|
||||||
@ -1097,7 +1097,7 @@ impl InterningDefinedSymbol {
|
|||||||
};
|
};
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// is a method call
|
// is a method call
|
||||||
if let ExprKind::MethodCall(_, _, [item], _) = call.kind;
|
if let ExprKind::MethodCall(_, [item], _) = call.kind;
|
||||||
if let Some(did) = cx.typeck_results().type_dependent_def_id(call.hir_id);
|
if let Some(did) = cx.typeck_results().type_dependent_def_id(call.hir_id);
|
||||||
let ty = cx.typeck_results().expr_ty(item);
|
let ty = cx.typeck_results().expr_ty(item);
|
||||||
// ...on either an Ident or a Symbol
|
// ...on either an Ident or a Symbol
|
||||||
|
@ -896,7 +896,7 @@ impl<'a, 'hir> intravisit::Visitor<'hir> for IsMultiSpanScanner<'a, 'hir> {
|
|||||||
self.add_single_span_suggestion();
|
self.add_single_span_suggestion();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(path, _path_span, arg, _arg_span) => {
|
ExprKind::MethodCall(path, arg, _arg_span) => {
|
||||||
let (self_ty, _) = walk_ptrs_ty_depth(self.cx.typeck_results().expr_ty(&arg[0]));
|
let (self_ty, _) = walk_ptrs_ty_depth(self.cx.typeck_results().expr_ty(&arg[0]));
|
||||||
if match_type(self.cx, self_ty, &paths::DIAGNOSTIC_BUILDER) {
|
if match_type(self.cx, self_ty, &paths::DIAGNOSTIC_BUILDER) {
|
||||||
let called_method = path.ident.name.as_str().to_string();
|
let called_method = path.ident.name.as_str().to_string();
|
||||||
|
@ -125,7 +125,7 @@ impl<'tcx> LateLintPass<'tcx> for VecInitThenPush {
|
|||||||
if let Some(searcher) = self.searcher.take() {
|
if let Some(searcher) = self.searcher.take() {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let StmtKind::Expr(expr) | StmtKind::Semi(expr) = stmt.kind;
|
if let StmtKind::Expr(expr) | StmtKind::Semi(expr) = stmt.kind;
|
||||||
if let ExprKind::MethodCall(path, _, [self_arg, _], _) = expr.kind;
|
if let ExprKind::MethodCall(path, [self_arg, _], _) = expr.kind;
|
||||||
if path_to_local_id(self_arg, searcher.local_id);
|
if path_to_local_id(self_arg, searcher.local_id);
|
||||||
if path.ident.name.as_str() == "push";
|
if path.ident.name.as_str() == "push";
|
||||||
then {
|
then {
|
||||||
|
@ -31,7 +31,7 @@ declare_lint_pass!(VecResizeToZero => [VEC_RESIZE_TO_ZERO]);
|
|||||||
impl<'tcx> LateLintPass<'tcx> for VecResizeToZero {
|
impl<'tcx> LateLintPass<'tcx> for VecResizeToZero {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let hir::ExprKind::MethodCall(path_segment, _, args, _) = expr.kind;
|
if let hir::ExprKind::MethodCall(path_segment, args, _) = expr.kind;
|
||||||
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
if let Some(method_def_id) = cx.typeck_results().type_dependent_def_id(expr.hir_id);
|
||||||
if match_def_path(cx, method_def_id, &paths::VEC_RESIZE) && args.len() == 3;
|
if match_def_path(cx, method_def_id, &paths::VEC_RESIZE) && args.len() == 3;
|
||||||
if let ExprKind::Lit(Spanned { node: LitKind::Int(0, _), .. }) = args[1].kind;
|
if let ExprKind::Lit(Spanned { node: LitKind::Int(0, _), .. }) = args[1].kind;
|
||||||
|
@ -61,7 +61,7 @@ impl<'tcx> LateLintPass<'tcx> for VerboseFileReads {
|
|||||||
|
|
||||||
fn is_file_read_to_end<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) -> bool {
|
fn is_file_read_to_end<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) -> bool {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, exprs, _) = expr.kind;
|
if let ExprKind::MethodCall(method_name, exprs, _) = expr.kind;
|
||||||
if method_name.ident.as_str() == "read_to_end";
|
if method_name.ident.as_str() == "read_to_end";
|
||||||
if let ExprKind::Path(QPath::Resolved(None, _)) = &exprs[0].kind;
|
if let ExprKind::Path(QPath::Resolved(None, _)) = &exprs[0].kind;
|
||||||
let ty = cx.typeck_results().expr_ty(&exprs[0]);
|
let ty = cx.typeck_results().expr_ty(&exprs[0]);
|
||||||
@ -75,7 +75,7 @@ fn is_file_read_to_end<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) ->
|
|||||||
|
|
||||||
fn is_file_read_to_string<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) -> bool {
|
fn is_file_read_to_string<'tcx>(cx: &LateContext<'tcx>, expr: &'tcx Expr<'tcx>) -> bool {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, exprs, _) = expr.kind;
|
if let ExprKind::MethodCall(method_name, exprs, _) = expr.kind;
|
||||||
if method_name.ident.as_str() == "read_to_string";
|
if method_name.ident.as_str() == "read_to_string";
|
||||||
if let ExprKind::Path(QPath::Resolved(None, _)) = &exprs[0].kind;
|
if let ExprKind::Path(QPath::Resolved(None, _)) = &exprs[0].kind;
|
||||||
let ty = cx.typeck_results().expr_ty(&exprs[0]);
|
let ty = cx.typeck_results().expr_ty(&exprs[0]);
|
||||||
|
@ -141,7 +141,7 @@ fn expr_eagerness<'tcx>(cx: &LateContext<'tcx>, e: &'tcx Expr<'_>) -> EagernessS
|
|||||||
self.eagerness |= NoChange;
|
self.eagerness |= NoChange;
|
||||||
return;
|
return;
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(name, _, args, _) => {
|
ExprKind::MethodCall(name, args, _) => {
|
||||||
self.eagerness |= self
|
self.eagerness |= self
|
||||||
.cx
|
.cx
|
||||||
.typeck_results()
|
.typeck_results()
|
||||||
|
@ -258,7 +258,7 @@ impl HirEqInterExpr<'_, '_, '_> {
|
|||||||
&& self.eq_expr(l.body, r.body)
|
&& self.eq_expr(l.body, r.body)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
(&ExprKind::MethodCall(l_path, _, l_args, _), &ExprKind::MethodCall(r_path, _, r_args, _)) => {
|
(&ExprKind::MethodCall(l_path, l_args, _), &ExprKind::MethodCall(r_path, r_args, _)) => {
|
||||||
self.inner.allow_side_effects && self.eq_path_segment(l_path, r_path) && self.eq_exprs(l_args, r_args)
|
self.inner.allow_side_effects && self.eq_path_segment(l_path, r_path) && self.eq_exprs(l_args, r_args)
|
||||||
},
|
},
|
||||||
(&ExprKind::Repeat(le, ll), &ExprKind::Repeat(re, rl)) => {
|
(&ExprKind::Repeat(le, ll), &ExprKind::Repeat(re, rl)) => {
|
||||||
@ -713,7 +713,7 @@ impl<'a, 'tcx> SpanlessHash<'a, 'tcx> {
|
|||||||
|
|
||||||
s.hash(&mut self.s);
|
s.hash(&mut self.s);
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(path, ref _tys, args, ref _fn_span) => {
|
ExprKind::MethodCall(path, args, ref _fn_span) => {
|
||||||
self.hash_name(path.ident.name);
|
self.hash_name(path.ident.name);
|
||||||
self.hash_exprs(args);
|
self.hash_exprs(args);
|
||||||
},
|
},
|
||||||
|
@ -1059,13 +1059,13 @@ pub fn method_calls<'tcx>(
|
|||||||
|
|
||||||
let mut current = expr;
|
let mut current = expr;
|
||||||
for _ in 0..max_depth {
|
for _ in 0..max_depth {
|
||||||
if let ExprKind::MethodCall(path, span, args, _) = ¤t.kind {
|
if let ExprKind::MethodCall(path, args, _) = ¤t.kind {
|
||||||
if args.iter().any(|e| e.span.from_expansion()) {
|
if args.iter().any(|e| e.span.from_expansion()) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
method_names.push(path.ident.name);
|
method_names.push(path.ident.name);
|
||||||
arg_lists.push(&**args);
|
arg_lists.push(&**args);
|
||||||
spans.push(*span);
|
spans.push(path.ident.span);
|
||||||
current = &args[0];
|
current = &args[0];
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
@ -1086,7 +1086,7 @@ pub fn method_chain_args<'a>(expr: &'a Expr<'_>, methods: &[&str]) -> Option<Vec
|
|||||||
let mut matched = Vec::with_capacity(methods.len());
|
let mut matched = Vec::with_capacity(methods.len());
|
||||||
for method_name in methods.iter().rev() {
|
for method_name in methods.iter().rev() {
|
||||||
// method chains are stored last -> first
|
// method chains are stored last -> first
|
||||||
if let ExprKind::MethodCall(path, _, args, _) = current.kind {
|
if let ExprKind::MethodCall(path, args, _) = current.kind {
|
||||||
if path.ident.name.as_str() == *method_name {
|
if path.ident.name.as_str() == *method_name {
|
||||||
if args.iter().any(|e| e.span.from_expansion()) {
|
if args.iter().any(|e| e.span.from_expansion()) {
|
||||||
return None;
|
return None;
|
||||||
@ -1780,7 +1780,7 @@ pub fn is_must_use_func_call(cx: &LateContext<'_>, expr: &Expr<'_>) -> bool {
|
|||||||
None
|
None
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ExprKind::MethodCall(_, _, _, _) => cx.typeck_results().type_dependent_def_id(expr.hir_id),
|
ExprKind::MethodCall(..) => cx.typeck_results().type_dependent_def_id(expr.hir_id),
|
||||||
_ => None,
|
_ => None,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@ fn extract_clone_suggestions<'tcx>(
|
|||||||
if abort {
|
if abort {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if let ExprKind::MethodCall(seg, _, [recv], _) = expr.kind {
|
if let ExprKind::MethodCall(seg, [recv], _) = expr.kind {
|
||||||
if path_to_local_id(recv, id) {
|
if path_to_local_id(recv, id) {
|
||||||
if seg.ident.name.as_str() == "capacity" {
|
if seg.ident.name.as_str() == "capacity" {
|
||||||
abort = true;
|
abort = true;
|
||||||
|
@ -863,7 +863,7 @@ impl<'tcx> DerefDelegate<'_, 'tcx> {
|
|||||||
/// indicates whether the function from `parent_expr` takes its args by double reference
|
/// indicates whether the function from `parent_expr` takes its args by double reference
|
||||||
fn func_takes_arg_by_double_ref(&self, parent_expr: &'tcx hir::Expr<'_>, cmt_hir_id: HirId) -> bool {
|
fn func_takes_arg_by_double_ref(&self, parent_expr: &'tcx hir::Expr<'_>, cmt_hir_id: HirId) -> bool {
|
||||||
let (call_args, inputs) = match parent_expr.kind {
|
let (call_args, inputs) = match parent_expr.kind {
|
||||||
ExprKind::MethodCall(_, _, call_args, _) => {
|
ExprKind::MethodCall(_, call_args, _) => {
|
||||||
if let Some(method_did) = self.cx.typeck_results().type_dependent_def_id(parent_expr.hir_id) {
|
if let Some(method_did) = self.cx.typeck_results().type_dependent_def_id(parent_expr.hir_id) {
|
||||||
(call_args, self.cx.tcx.fn_sig(method_did).skip_binder().inputs())
|
(call_args, self.cx.tcx.fn_sig(method_did).skip_binder().inputs())
|
||||||
} else {
|
} else {
|
||||||
@ -915,7 +915,7 @@ impl<'tcx> Delegate<'tcx> for DerefDelegate<'_, 'tcx> {
|
|||||||
match &parent_expr.kind {
|
match &parent_expr.kind {
|
||||||
// given expression is the self argument and will be handled completely by the compiler
|
// given expression is the self argument and will be handled completely by the compiler
|
||||||
// i.e.: `|x| x.is_something()`
|
// i.e.: `|x| x.is_something()`
|
||||||
ExprKind::MethodCall(_, _, [self_expr, ..], _) if self_expr.hir_id == cmt.hir_id => {
|
ExprKind::MethodCall(_, [self_expr, ..], _) if self_expr.hir_id == cmt.hir_id => {
|
||||||
self.suggestion_start
|
self.suggestion_start
|
||||||
.push_str(&format!("{}{}", start_snip, ident_str_with_proj));
|
.push_str(&format!("{}{}", start_snip, ident_str_with_proj));
|
||||||
self.next_pos = span.hi();
|
self.next_pos = span.hi();
|
||||||
@ -923,7 +923,7 @@ impl<'tcx> Delegate<'tcx> for DerefDelegate<'_, 'tcx> {
|
|||||||
},
|
},
|
||||||
// item is used in a call
|
// item is used in a call
|
||||||
// i.e.: `Call`: `|x| please(x)` or `MethodCall`: `|x| [1, 2, 3].contains(x)`
|
// i.e.: `Call`: `|x| please(x)` or `MethodCall`: `|x| [1, 2, 3].contains(x)`
|
||||||
ExprKind::Call(_, [call_args @ ..]) | ExprKind::MethodCall(_, _, [_, call_args @ ..], _) => {
|
ExprKind::Call(_, [call_args @ ..]) | ExprKind::MethodCall(_, [_, call_args @ ..], _) => {
|
||||||
let expr = self.cx.tcx.hir().expect_expr(cmt.hir_id);
|
let expr = self.cx.tcx.hir().expect_expr(cmt.hir_id);
|
||||||
let arg_ty_kind = self.cx.typeck_results().expr_ty(expr).kind();
|
let arg_ty_kind = self.cx.typeck_results().expr_ty(expr).kind();
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ impl<'tcx> LateLintPass<'tcx> for MyStructLint {
|
|||||||
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx hir::Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'tcx>, expr: &'tcx hir::Expr<'_>) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
// Check our expr is calling a method
|
// Check our expr is calling a method
|
||||||
if let hir::ExprKind::MethodCall(path, _, [_self_arg, ..], _) = &expr.kind;
|
if let hir::ExprKind::MethodCall(path, _, [_self_arg, ..]) = &expr.kind;
|
||||||
// Check the name of this method is `some_method`
|
// Check the name of this method is `some_method`
|
||||||
if path.ident.name == sym!(some_method);
|
if path.ident.name == sym!(some_method);
|
||||||
// Optionally, check the type of the self argument.
|
// Optionally, check the type of the self argument.
|
||||||
|
@ -53,7 +53,7 @@ if_chain! {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ExprKind::MethodCall(method_name, _, args, _) = expr.kind;
|
if let ExprKind::MethodCall(method_name, args, _) = expr.kind;
|
||||||
if method_name.ident.as_str() == "test";
|
if method_name.ident.as_str() == "test";
|
||||||
if args.len() == 1;
|
if args.len() == 1;
|
||||||
if let ExprKind::Path(ref qpath) = args[0].kind;
|
if let ExprKind::Path(ref qpath) = args[0].kind;
|
||||||
|
Loading…
Reference in New Issue
Block a user