mirror of
https://github.com/rust-lang/rust.git
synced 2025-04-28 11:07:42 +00:00
Auto merge of #3577 - daxpedda:master, r=flip1995
Fix false positives for `implicit_return` and `empty_loop` on macro expansion. This PR only fixes `implicit_return` and `empty_loop`. But I suspect this bug may affect a lot of other lints.
This commit is contained in:
commit
721f688eff
@ -12,7 +12,7 @@ use crate::rustc::lint::{LateContext, LateLintPass, LintArray, LintPass};
|
|||||||
use crate::rustc::{declare_tool_lint, lint_array};
|
use crate::rustc::{declare_tool_lint, lint_array};
|
||||||
use crate::rustc_errors::Applicability;
|
use crate::rustc_errors::Applicability;
|
||||||
use crate::syntax::{ast::NodeId, source_map::Span};
|
use crate::syntax::{ast::NodeId, source_map::Span};
|
||||||
use crate::utils::{snippet_opt, span_lint_and_then};
|
use crate::utils::{in_macro, snippet_opt, span_lint_and_then};
|
||||||
|
|
||||||
/// **What it does:** Checks for missing return statements at the end of a block.
|
/// **What it does:** Checks for missing return statements at the end of a block.
|
||||||
///
|
///
|
||||||
@ -116,14 +116,15 @@ impl<'a, 'tcx> LateLintPass<'a, 'tcx> for Pass {
|
|||||||
_: FnKind<'tcx>,
|
_: FnKind<'tcx>,
|
||||||
_: &'tcx FnDecl,
|
_: &'tcx FnDecl,
|
||||||
body: &'tcx Body,
|
body: &'tcx Body,
|
||||||
_: Span,
|
span: Span,
|
||||||
_: NodeId,
|
_: NodeId,
|
||||||
) {
|
) {
|
||||||
let def_id = cx.tcx.hir().body_owner_def_id(body.id());
|
let def_id = cx.tcx.hir().body_owner_def_id(body.id());
|
||||||
let mir = cx.tcx.optimized_mir(def_id);
|
let mir = cx.tcx.optimized_mir(def_id);
|
||||||
|
|
||||||
// checking return type through MIR, HIR is not able to determine inferred closure return types
|
// checking return type through MIR, HIR is not able to determine inferred closure return types
|
||||||
if !mir.return_ty().is_unit() {
|
// make sure it's not a macro
|
||||||
|
if !mir.return_ty().is_unit() && !in_macro(span) {
|
||||||
Self::expr_match(cx, &body.value);
|
Self::expr_match(cx, &body.value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -478,6 +478,11 @@ impl LintPass for Pass {
|
|||||||
|
|
||||||
impl<'a, 'tcx> LateLintPass<'a, 'tcx> for Pass {
|
impl<'a, 'tcx> LateLintPass<'a, 'tcx> for Pass {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'a, 'tcx>, expr: &'tcx Expr) {
|
fn check_expr(&mut self, cx: &LateContext<'a, 'tcx>, expr: &'tcx Expr) {
|
||||||
|
// we don't want to check expanded macros
|
||||||
|
if in_macro(expr.span) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if let Some((pat, arg, body)) = higher::for_loop(expr) {
|
if let Some((pat, arg, body)) = higher::for_loop(expr) {
|
||||||
check_for_loop(cx, pat, arg, body, expr);
|
check_for_loop(cx, pat, arg, body, expr);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user