mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-20 19:52:48 +00:00
add manual_ok_or / pr remarks
This commit is contained in:
parent
111b9023da
commit
d780f61d7b
@ -1,4 +1,6 @@
|
||||
use crate::utils;
|
||||
use crate::utils::{
|
||||
indent_of, is_type_diagnostic_item, match_qpath, paths, reindent_multiline, snippet_opt, span_lint_and_sugg,
|
||||
};
|
||||
use if_chain::if_chain;
|
||||
use rustc_errors::Applicability;
|
||||
use rustc_hir::{def, Expr, ExprKind, PatKind, QPath};
|
||||
@ -49,18 +51,18 @@ impl LateLintPass<'_> for ManualOkOr {
|
||||
if args.len() == 3;
|
||||
let method_receiver = &args[0];
|
||||
let ty = cx.typeck_results().expr_ty(method_receiver);
|
||||
if utils::is_type_diagnostic_item(cx, ty, sym!(option_type));
|
||||
if is_type_diagnostic_item(cx, ty, sym!(option_type));
|
||||
let or_expr = &args[1];
|
||||
if is_ok_wrapping(cx, &args[2]);
|
||||
if let ExprKind::Call(Expr { kind: ExprKind::Path(err_path), .. }, &[ref err_arg]) = or_expr.kind;
|
||||
if utils::match_qpath(err_path, &utils::paths::RESULT_ERR);
|
||||
if let Some(method_receiver_snippet) = utils::snippet_opt(cx, method_receiver.span);
|
||||
if let Some(err_arg_snippet) = utils::snippet_opt(cx, err_arg.span);
|
||||
if let Some(indent) = utils::indent_of(cx, scrutinee.span);
|
||||
if match_qpath(err_path, &paths::RESULT_ERR);
|
||||
if let Some(method_receiver_snippet) = snippet_opt(cx, method_receiver.span);
|
||||
if let Some(err_arg_snippet) = snippet_opt(cx, err_arg.span);
|
||||
if let Some(indent) = indent_of(cx, scrutinee.span);
|
||||
then {
|
||||
let reindented_err_arg_snippet =
|
||||
utils::reindent_multiline(err_arg_snippet.into(), true, Some(indent + 4));
|
||||
utils::span_lint_and_sugg(
|
||||
reindent_multiline(err_arg_snippet.into(), true, Some(indent + 4));
|
||||
span_lint_and_sugg(
|
||||
cx,
|
||||
MANUAL_OK_OR,
|
||||
scrutinee.span,
|
||||
@ -80,7 +82,7 @@ impl LateLintPass<'_> for ManualOkOr {
|
||||
|
||||
fn is_ok_wrapping(cx: &LateContext<'_>, map_expr: &Expr<'_>) -> bool {
|
||||
if let ExprKind::Path(ref qpath) = map_expr.kind {
|
||||
if utils::match_qpath(qpath, &utils::paths::RESULT_OK) {
|
||||
if match_qpath(qpath, &paths::RESULT_OK) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@ -89,7 +91,7 @@ fn is_ok_wrapping(cx: &LateContext<'_>, map_expr: &Expr<'_>) -> bool {
|
||||
let body = cx.tcx.hir().body(body_id);
|
||||
if let PatKind::Binding(_, param_id, ..) = body.params[0].pat.kind;
|
||||
if let ExprKind::Call(Expr { kind: ExprKind::Path(ok_path), .. }, &[ref ok_arg]) = body.value.kind;
|
||||
if utils::match_qpath(ok_path, &utils::paths::RESULT_OK);
|
||||
if match_qpath(ok_path, &paths::RESULT_OK);
|
||||
if let ExprKind::Path(QPath::Resolved(_, ok_arg_path)) = ok_arg.kind;
|
||||
if let def::Res::Local(ok_arg_path_id) = ok_arg_path.res;
|
||||
then { param_id == ok_arg_path_id } else { false }
|
||||
|
Loading…
Reference in New Issue
Block a user