From ec448ca4b33202e384eb034b4e15ed751355488c Mon Sep 17 00:00:00 2001 From: Lukas Wirth Date: Sat, 2 Jan 2021 00:42:07 +0100 Subject: Impl HasAttrs for GenericParam --- crates/hir_def/src/lib.rs | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'crates/hir_def/src/lib.rs') diff --git a/crates/hir_def/src/lib.rs b/crates/hir_def/src/lib.rs index 25f460504..211cb2faf 100644 --- a/crates/hir_def/src/lib.rs +++ b/crates/hir_def/src/lib.rs @@ -261,6 +261,15 @@ pub enum AdtId { } impl_from!(StructId, UnionId, EnumId for AdtId); +/// A generic param +#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash)] +pub enum GenericParamId { + TypeParamId(TypeParamId), + LifetimeParamId(LifetimeParamId), + ConstParamId(ConstParamId), +} +impl_from!(TypeParamId, LifetimeParamId, ConstParamId for GenericParamId); + /// The defs which can be visible in the module. #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] pub enum ModuleDefId { @@ -357,6 +366,7 @@ pub enum AttrDefId { TypeAliasId(TypeAliasId), MacroDefId(MacroDefId), ImplId(ImplId), + GenericParamId(GenericParamId), } impl_from!( @@ -370,7 +380,8 @@ impl_from!( TraitId, TypeAliasId, MacroDefId, - ImplId + ImplId, + GenericParamId for AttrDefId ); @@ -495,6 +506,15 @@ impl AttrDefId { AttrDefId::TraitId(it) => it.lookup(db).container.module(db).krate, AttrDefId::TypeAliasId(it) => it.lookup(db).module(db).krate, AttrDefId::ImplId(it) => it.lookup(db).container.module(db).krate, + AttrDefId::GenericParamId(it) => { + match it { + GenericParamId::TypeParamId(it) => it.parent, + GenericParamId::LifetimeParamId(it) => it.parent, + GenericParamId::ConstParamId(it) => it.parent, + } + .module(db) + .krate + } // FIXME: `MacroDefId` should store the defining module, then this can implement // `HasModule` AttrDefId::MacroDefId(it) => it.krate, -- cgit v1.2.3