2021-03-25 19:29:11 +01:00
|
|
|
use clippy_utils::diagnostics::span_lint_and_help;
|
|
|
|
use clippy_utils::ty::is_type_diagnostic_item;
|
2021-03-12 15:30:50 +01:00
|
|
|
use rustc_hir as hir;
|
|
|
|
use rustc_lint::LateContext;
|
|
|
|
use rustc_span::sym;
|
|
|
|
|
|
|
|
use super::EXPECT_USED;
|
|
|
|
|
|
|
|
/// lint use of `expect()` for `Option`s and `Result`s
|
2021-04-08 17:50:13 +02:00
|
|
|
pub(super) fn check(cx: &LateContext<'_>, expr: &hir::Expr<'_>, recv: &hir::Expr<'_>) {
|
|
|
|
let obj_ty = cx.typeck_results().expr_ty(recv).peel_refs();
|
2021-03-12 15:30:50 +01:00
|
|
|
|
2021-10-02 18:51:01 -05:00
|
|
|
let mess = if is_type_diagnostic_item(cx, obj_ty, sym::Option) {
|
2021-03-12 15:30:50 +01:00
|
|
|
Some((EXPECT_USED, "an Option", "None"))
|
2021-10-02 18:51:01 -05:00
|
|
|
} else if is_type_diagnostic_item(cx, obj_ty, sym::Result) {
|
2021-03-12 15:30:50 +01:00
|
|
|
Some((EXPECT_USED, "a Result", "Err"))
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
|
|
|
|
|
|
|
if let Some((lint, kind, none_value)) = mess {
|
|
|
|
span_lint_and_help(
|
|
|
|
cx,
|
|
|
|
lint,
|
|
|
|
expr.span,
|
|
|
|
&format!("used `expect()` on `{}` value", kind,),
|
|
|
|
None,
|
|
|
|
&format!("if this value is an `{}`, it will panic", none_value,),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|