2021-03-25 18:29:11 +00:00
|
|
|
use clippy_utils::diagnostics::span_lint_and_help;
|
|
|
|
use clippy_utils::ty::is_type_diagnostic_item;
|
2022-10-21 13:27:25 +00:00
|
|
|
use clippy_utils::{is_in_cfg_test, is_lint_allowed};
|
2021-03-12 14:30:50 +00:00
|
|
|
use rustc_hir as hir;
|
|
|
|
use rustc_lint::LateContext;
|
|
|
|
use rustc_span::sym;
|
|
|
|
|
2022-07-21 20:45:12 +00:00
|
|
|
use super::{EXPECT_USED, UNWRAP_USED};
|
2021-03-12 14:30:50 +00:00
|
|
|
|
2022-08-15 18:30:30 +00:00
|
|
|
/// lint use of `unwrap()` or `unwrap_err` for `Result` and `unwrap()` for `Option`.
|
|
|
|
pub(super) fn check(
|
|
|
|
cx: &LateContext<'_>,
|
|
|
|
expr: &hir::Expr<'_>,
|
|
|
|
recv: &hir::Expr<'_>,
|
|
|
|
is_err: bool,
|
|
|
|
allow_unwrap_in_tests: bool,
|
|
|
|
) {
|
2021-04-08 15:50:13 +00:00
|
|
|
let obj_ty = cx.typeck_results().expr_ty(recv).peel_refs();
|
2021-03-12 14:30:50 +00:00
|
|
|
|
2022-08-15 18:30:30 +00:00
|
|
|
let mess = if is_type_diagnostic_item(cx, obj_ty, sym::Option) && !is_err {
|
2022-11-17 14:57:39 +00:00
|
|
|
Some((UNWRAP_USED, "an `Option`", "None", ""))
|
2021-10-02 23:51:01 +00:00
|
|
|
} else if is_type_diagnostic_item(cx, obj_ty, sym::Result) {
|
2022-11-17 14:57:39 +00:00
|
|
|
Some((UNWRAP_USED, "a `Result`", if is_err { "Ok" } else { "Err" }, "an "))
|
2021-03-12 14:30:50 +00:00
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
|
|
|
|
2022-08-17 16:58:17 +00:00
|
|
|
let method_suffix = if is_err { "_err" } else { "" };
|
2022-08-15 18:30:30 +00:00
|
|
|
|
2022-10-21 13:27:25 +00:00
|
|
|
if allow_unwrap_in_tests && is_in_cfg_test(cx.tcx, expr.hir_id) {
|
2022-05-08 10:44:58 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-07-22 17:14:31 +00:00
|
|
|
if let Some((lint, kind, none_value, none_prefix)) = mess {
|
2022-07-21 20:45:12 +00:00
|
|
|
let help = if is_lint_allowed(cx, EXPECT_USED, expr.hir_id) {
|
|
|
|
format!(
|
|
|
|
"if you don't want to handle the `{none_value}` case gracefully, consider \
|
2022-08-17 16:58:17 +00:00
|
|
|
using `expect{method_suffix}()` to provide a better panic message"
|
2022-07-21 20:45:12 +00:00
|
|
|
)
|
|
|
|
} else {
|
2022-07-22 17:14:31 +00:00
|
|
|
format!("if this value is {none_prefix}`{none_value}`, it will panic")
|
2022-07-21 20:45:12 +00:00
|
|
|
};
|
|
|
|
|
2021-03-12 14:30:50 +00:00
|
|
|
span_lint_and_help(
|
|
|
|
cx,
|
|
|
|
lint,
|
|
|
|
expr.span,
|
2022-11-17 14:57:39 +00:00
|
|
|
&format!("used `unwrap{method_suffix}()` on {kind} value"),
|
2021-03-12 14:30:50 +00:00
|
|
|
None,
|
2022-07-21 20:45:12 +00:00
|
|
|
&help,
|
2021-03-12 14:30:50 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|