//! Utility module for converting between hir_def ids and code_model wrappers. //! //! It's unclear if we need this long-term, but it's definitelly useful while we //! are splitting the hir. use hir_def::{ expr::PatId, AdtId, AssocItemId, AttrDefId, DefWithBodyId, EnumVariantId, GenericDefId, ModuleDefId, StructFieldId, VariantId, }; use crate::{ Adt, AssocItem, AttrDef, DefWithBody, EnumVariant, GenericDef, Local, ModuleDef, StructField, VariantDef, }; macro_rules! from_id { ($(($id:path, $ty:path)),*) => {$( impl From<$id> for $ty { fn from(id: $id) -> $ty { $ty { id } } } impl From<$ty> for $id { fn from(ty: $ty) -> $id { ty.id } } )*} } from_id![ (ra_db::CrateId, crate::Crate), (hir_def::ModuleId, crate::Module), (hir_def::StructId, crate::Struct), (hir_def::UnionId, crate::Union), (hir_def::EnumId, crate::Enum), (hir_def::TypeAliasId, crate::TypeAlias), (hir_def::TraitId, crate::Trait), (hir_def::StaticId, crate::Static), (hir_def::ConstId, crate::Const), (hir_def::FunctionId, crate::Function), (hir_def::ImplId, crate::ImplBlock), (hir_def::TypeParamId, crate::TypeParam), (hir_expand::MacroDefId, crate::MacroDef) ]; impl From for Adt { fn from(id: AdtId) -> Self { match id { AdtId::StructId(it) => Adt::Struct(it.into()), AdtId::UnionId(it) => Adt::Union(it.into()), AdtId::EnumId(it) => Adt::Enum(it.into()), } } } impl From for AdtId { fn from(id: Adt) -> Self { match id { Adt::Struct(it) => AdtId::StructId(it.id), Adt::Union(it) => AdtId::UnionId(it.id), Adt::Enum(it) => AdtId::EnumId(it.id), } } } impl From for EnumVariant { fn from(id: EnumVariantId) -> Self { EnumVariant { parent: id.parent.into(), id: id.local_id } } } impl From for EnumVariantId { fn from(def: EnumVariant) -> Self { EnumVariantId { parent: def.parent.id, local_id: def.id } } } impl From for ModuleDef { fn from(id: ModuleDefId) -> Self { match id { ModuleDefId::ModuleId(it) => ModuleDef::Module(it.into()), ModuleDefId::FunctionId(it) => ModuleDef::Function(it.into()), ModuleDefId::AdtId(it) => ModuleDef::Adt(it.into()), ModuleDefId::EnumVariantId(it) => ModuleDef::EnumVariant(it.into()), ModuleDefId::ConstId(it) => ModuleDef::Const(it.into()), ModuleDefId::StaticId(it) => ModuleDef::Static(it.into()), ModuleDefId::TraitId(it) => ModuleDef::Trait(it.into()), ModuleDefId::TypeAliasId(it) => ModuleDef::TypeAlias(it.into()), ModuleDefId::BuiltinType(it) => ModuleDef::BuiltinType(it), } } } impl From for ModuleDefId { fn from(id: ModuleDef) -> Self { match id { ModuleDef::Module(it) => ModuleDefId::ModuleId(it.into()), ModuleDef::Function(it) => ModuleDefId::FunctionId(it.into()), ModuleDef::Adt(it) => ModuleDefId::AdtId(it.into()), ModuleDef::EnumVariant(it) => ModuleDefId::EnumVariantId(it.into()), ModuleDef::Const(it) => ModuleDefId::ConstId(it.into()), ModuleDef::Static(it) => ModuleDefId::StaticId(it.into()), ModuleDef::Trait(it) => ModuleDefId::TraitId(it.into()), ModuleDef::TypeAlias(it) => ModuleDefId::TypeAliasId(it.into()), ModuleDef::BuiltinType(it) => ModuleDefId::BuiltinType(it), } } } impl From for DefWithBodyId { fn from(def: DefWithBody) -> Self { match def { DefWithBody::Function(it) => DefWithBodyId::FunctionId(it.id), DefWithBody::Static(it) => DefWithBodyId::StaticId(it.id), DefWithBody::Const(it) => DefWithBodyId::ConstId(it.id), } } } impl From for DefWithBody { fn from(def: DefWithBodyId) -> Self { match def { DefWithBodyId::FunctionId(it) => DefWithBody::Function(it.into()), DefWithBodyId::StaticId(it) => DefWithBody::Static(it.into()), DefWithBodyId::ConstId(it) => DefWithBody::Const(it.into()), } } } impl From for AssocItem { fn from(def: AssocItemId) -> Self { match def { AssocItemId::FunctionId(it) => AssocItem::Function(it.into()), AssocItemId::TypeAliasId(it) => AssocItem::TypeAlias(it.into()), AssocItemId::ConstId(it) => AssocItem::Const(it.into()), } } } impl From for GenericDefId { fn from(def: GenericDef) -> Self { match def { GenericDef::Function(it) => GenericDefId::FunctionId(it.id), GenericDef::Adt(it) => GenericDefId::AdtId(it.into()), GenericDef::Trait(it) => GenericDefId::TraitId(it.id), GenericDef::TypeAlias(it) => GenericDefId::TypeAliasId(it.id), GenericDef::ImplBlock(it) => GenericDefId::ImplId(it.id), GenericDef::EnumVariant(it) => { GenericDefId::EnumVariantId(EnumVariantId { parent: it.parent.id, local_id: it.id }) } GenericDef::Const(it) => GenericDefId::ConstId(it.id), } } } impl From for GenericDefId { fn from(id: Adt) -> Self { match id { Adt::Struct(it) => it.id.into(), Adt::Union(it) => it.id.into(), Adt::Enum(it) => it.id.into(), } } } impl From for VariantDef { fn from(def: VariantId) -> Self { match def { VariantId::StructId(it) => VariantDef::Struct(it.into()), VariantId::EnumVariantId(it) => VariantDef::EnumVariant(it.into()), VariantId::UnionId(it) => VariantDef::Union(it.into()), } } } impl From for VariantId { fn from(def: VariantDef) -> Self { match def { VariantDef::Struct(it) => VariantId::StructId(it.id), VariantDef::EnumVariant(it) => VariantId::EnumVariantId(it.into()), VariantDef::Union(it) => VariantId::UnionId(it.id), } } } impl From for StructFieldId { fn from(def: StructField) -> Self { StructFieldId { parent: def.parent.into(), local_id: def.id } } } impl From for StructField { fn from(def: StructFieldId) -> Self { StructField { parent: def.parent.into(), id: def.local_id } } } impl From for AttrDefId { fn from(def: AttrDef) -> Self { match def { AttrDef::Module(it) => AttrDefId::ModuleId(it.id), AttrDef::StructField(it) => AttrDefId::StructFieldId(it.into()), AttrDef::Adt(it) => AttrDefId::AdtId(it.into()), AttrDef::Function(it) => AttrDefId::FunctionId(it.id), AttrDef::EnumVariant(it) => AttrDefId::EnumVariantId(it.into()), AttrDef::Static(it) => AttrDefId::StaticId(it.id), AttrDef::Const(it) => AttrDefId::ConstId(it.id), AttrDef::Trait(it) => AttrDefId::TraitId(it.id), AttrDef::TypeAlias(it) => AttrDefId::TypeAliasId(it.id), AttrDef::MacroDef(it) => AttrDefId::MacroDefId(it.id), } } } impl From for GenericDefId { fn from(item: AssocItem) -> Self { match item { AssocItem::Function(f) => f.id.into(), AssocItem::Const(c) => c.id.into(), AssocItem::TypeAlias(t) => t.id.into(), } } } impl From<(DefWithBodyId, PatId)> for Local { fn from((parent, pat_id): (DefWithBodyId, PatId)) -> Self { Local { parent: parent.into(), pat_id } } }