2021-03-16 00:55:45 +00:00
|
|
|
use clippy_utils::diagnostics::span_lint;
|
|
|
|
use if_chain::if_chain;
|
2021-03-09 08:22:21 +00:00
|
|
|
use rustc_hir::{Expr, ExprKind, MutTy, Mutability, TyKind, UnOp};
|
|
|
|
use rustc_lint::LateContext;
|
|
|
|
use rustc_middle::ty;
|
|
|
|
|
|
|
|
use super::CAST_REF_TO_MUT;
|
|
|
|
|
2022-01-11 15:52:23 +00:00
|
|
|
pub(super) fn check(cx: &LateContext<'_>, expr: &Expr<'_>) {
|
2021-03-09 08:22:21 +00:00
|
|
|
if_chain! {
|
|
|
|
if let ExprKind::Unary(UnOp::Deref, e) = &expr.kind;
|
|
|
|
if let ExprKind::Cast(e, t) = &e.kind;
|
|
|
|
if let TyKind::Ptr(MutTy { mutbl: Mutability::Mut, .. }) = t.kind;
|
|
|
|
if let ExprKind::Cast(e, t) = &e.kind;
|
|
|
|
if let TyKind::Ptr(MutTy { mutbl: Mutability::Not, .. }) = t.kind;
|
|
|
|
if let ty::Ref(..) = cx.typeck_results().node_type(e.hir_id).kind();
|
|
|
|
then {
|
|
|
|
span_lint(
|
|
|
|
cx,
|
|
|
|
CAST_REF_TO_MUT,
|
|
|
|
expr.span,
|
|
|
|
"casting `&T` to `&mut T` may cause undefined behavior, consider instead using an `UnsafeCell`",
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|