Skip to content

Commit

Permalink
Rollup merge of #103338 - l4l:enum-unreachable-pub, r=nagisa
Browse files Browse the repository at this point in the history
Fix unreachable_pub suggestion for enum with fields

Resolves #103317
  • Loading branch information
Dylan-DPC authored Oct 31, 2022
2 parents 4596f4f + 137271a commit 5ee0fb1
Show file tree
Hide file tree
Showing 4 changed files with 51 additions and 2 deletions.
8 changes: 6 additions & 2 deletions compiler/rustc_lint/src/builtin.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ use rustc_feature::{deprecated_attributes, AttributeGate, BuiltinAttribute, Gate
use rustc_hir as hir;
use rustc_hir::def::{DefKind, Res};
use rustc_hir::def_id::{DefId, LocalDefId, LocalDefIdSet, CRATE_DEF_ID};
use rustc_hir::{ForeignItemKind, GenericParamKind, HirId, PatKind, PredicateOrigin};
use rustc_hir::{ForeignItemKind, GenericParamKind, HirId, Node, PatKind, PredicateOrigin};
use rustc_index::vec::Idx;
use rustc_middle::lint::in_external_macro;
use rustc_middle::ty::layout::{LayoutError, LayoutOf};
Expand Down Expand Up @@ -1423,7 +1423,11 @@ impl<'tcx> LateLintPass<'tcx> for UnreachablePub {
}

fn check_field_def(&mut self, cx: &LateContext<'_>, field: &hir::FieldDef<'_>) {
let def_id = cx.tcx.hir().local_def_id(field.hir_id);
let map = cx.tcx.hir();
let def_id = map.local_def_id(field.hir_id);
if matches!(map.get(map.get_parent_node(field.hir_id)), Node::Variant(_)) {
return;
}
self.perform_lint(cx, "field", def_id, field.vis_span, false);
}

Expand Down
14 changes: 14 additions & 0 deletions src/test/ui/lint/issue-103317.fixed
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
// check-pass
// run-rustfix

#[warn(unreachable_pub)]
mod inner {
#[allow(unused)]
pub(crate) enum T {
//~^ WARN unreachable `pub` item
A(u8),
X { a: f32, b: () },
}
}

fn main() {}
14 changes: 14 additions & 0 deletions src/test/ui/lint/issue-103317.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
// check-pass
// run-rustfix

#[warn(unreachable_pub)]
mod inner {
#[allow(unused)]
pub enum T {
//~^ WARN unreachable `pub` item
A(u8),
X { a: f32, b: () },
}
}

fn main() {}
17 changes: 17 additions & 0 deletions src/test/ui/lint/issue-103317.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
warning: unreachable `pub` item
--> $DIR/issue-103317.rs:7:5
|
LL | pub enum T {
| ---^^^^^^^
| |
| help: consider restricting its visibility: `pub(crate)`
|
= help: or consider exporting it for use by other crates
note: the lint level is defined here
--> $DIR/issue-103317.rs:4:8
|
LL | #[warn(unreachable_pub)]
| ^^^^^^^^^^^^^^^

warning: 1 warning emitted

0 comments on commit 5ee0fb1

Please sign in to comment.