2021-03-16 00:55:45 +00:00
|
|
|
use clippy_utils::diagnostics::span_lint_and_help;
|
2021-03-13 23:01:03 +00:00
|
|
|
use clippy_utils::ty::is_type_diagnostic_item;
|
2021-03-02 15:14:38 +00:00
|
|
|
use rustc_hir as hir;
|
|
|
|
use rustc_lint::LateContext;
|
|
|
|
use rustc_span::sym;
|
|
|
|
|
|
|
|
use super::UNWRAP_USED;
|
|
|
|
|
|
|
|
/// lint use of `unwrap()` for `Option`s and `Result`s
|
2021-03-11 05:40:20 +00: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-02 15:14:38 +00:00
|
|
|
|
|
|
|
let mess = if is_type_diagnostic_item(cx, obj_ty, sym::option_type) {
|
|
|
|
Some((UNWRAP_USED, "an Option", "None"))
|
|
|
|
} else if is_type_diagnostic_item(cx, obj_ty, sym::result_type) {
|
|
|
|
Some((UNWRAP_USED, "a Result", "Err"))
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
|
|
|
|
|
|
|
if let Some((lint, kind, none_value)) = mess {
|
|
|
|
span_lint_and_help(
|
|
|
|
cx,
|
|
|
|
lint,
|
|
|
|
expr.span,
|
|
|
|
&format!("used `unwrap()` on `{}` value", kind,),
|
|
|
|
None,
|
|
|
|
&format!(
|
|
|
|
"if you don't want to handle the `{}` case gracefully, consider \
|
|
|
|
using `expect()` to provide a better panic message",
|
|
|
|
none_value,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|