From a0c52794bdbc83790b8a33bd9660e267556ef839 Mon Sep 17 00:00:00 2001 From: rainy-me Date: Sun, 12 Dec 2021 01:23:27 +0900 Subject: [PATCH] fix: lookup upwards for struct and enum --- crates/hir_ty/src/diagnostics/decl_check.rs | 8 ++++++-- crates/ide_diagnostics/src/handlers/incorrect_case.rs | 9 +++++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/crates/hir_ty/src/diagnostics/decl_check.rs b/crates/hir_ty/src/diagnostics/decl_check.rs index a1e7198bc2..9a0f457905 100644 --- a/crates/hir_ty/src/diagnostics/decl_check.rs +++ b/crates/hir_ty/src/diagnostics/decl_check.rs @@ -181,8 +181,12 @@ impl<'a> DeclValidator<'a> { AttrDefId::ExternBlockId(id) => Some(id.lookup(self.db.upcast()).container.into()), // These warnings should not explore macro definitions at all AttrDefId::MacroDefId(_) => None, - // Will never occur under an enum/struct/union/type alias - AttrDefId::AdtId(_) => None, + AttrDefId::AdtId(aid) => match aid { + AdtId::StructId(sid) => Some(sid.lookup(self.db.upcast()).container.into()), + AdtId::EnumId(eid) => Some(eid.lookup(self.db.upcast()).container.into()), + // Unions aren't yet supported + AdtId::UnionId(_) => None, + }, AttrDefId::FieldId(_) => None, AttrDefId::EnumVariantId(_) => None, AttrDefId::TypeAliasId(_) => None, diff --git a/crates/ide_diagnostics/src/handlers/incorrect_case.rs b/crates/ide_diagnostics/src/handlers/incorrect_case.rs index 3206a63a90..6a78c08d44 100644 --- a/crates/ide_diagnostics/src/handlers/incorrect_case.rs +++ b/crates/ide_diagnostics/src/handlers/incorrect_case.rs @@ -332,6 +332,15 @@ fn main() { check_diagnostics( r#" #![allow(non_snake_case)] +#![allow(non_camel_case_types)] + +struct S { + fooBar: bool, +} + +enum E { + fooBar, +} mod F { fn CheckItWorksWithCrateAttr(BAD_NAME_HI: u8) {}