2020-05-22 15:14:53 +00:00
|
|
|
//! This module contains the implementations of the `ToChalk` trait, which
|
|
|
|
//! handles conversion between our data types and their corresponding types in
|
|
|
|
//! Chalk (in both directions); plus some helper functions for more specialized
|
|
|
|
//! conversions.
|
|
|
|
|
2020-05-27 19:05:21 +00:00
|
|
|
use chalk_solve::rust_ir;
|
2020-05-22 15:14:53 +00:00
|
|
|
|
2021-04-09 12:28:04 +00:00
|
|
|
use base_db::salsa::{self, InternKey};
|
2021-12-29 13:35:59 +00:00
|
|
|
use hir_def::{LifetimeParamId, TraitId, TypeAliasId, TypeOrConstParamId};
|
2020-05-22 15:14:53 +00:00
|
|
|
|
2021-04-09 12:28:04 +00:00
|
|
|
use crate::{
|
|
|
|
chalk_db, db::HirDatabase, AssocTypeId, CallableDefId, ChalkTraitId, FnDefId, ForeignDefId,
|
|
|
|
Interner, OpaqueTyId, PlaceholderIndex,
|
|
|
|
};
|
2021-04-09 12:15:26 +00:00
|
|
|
|
|
|
|
pub(crate) trait ToChalk {
|
|
|
|
type Chalk;
|
|
|
|
fn to_chalk(self, db: &dyn HirDatabase) -> Self::Chalk;
|
|
|
|
fn from_chalk(db: &dyn HirDatabase, chalk: Self::Chalk) -> Self;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) fn from_chalk<T, ChalkT>(db: &dyn HirDatabase, chalk: ChalkT) -> T
|
|
|
|
where
|
|
|
|
T: ToChalk<Chalk = ChalkT>,
|
|
|
|
{
|
|
|
|
T::from_chalk(db, chalk)
|
|
|
|
}
|
2020-05-22 15:14:53 +00:00
|
|
|
|
2020-07-12 13:26:02 +00:00
|
|
|
impl ToChalk for hir_def::ImplId {
|
2021-04-09 12:11:37 +00:00
|
|
|
type Chalk = chalk_db::ImplId;
|
2020-05-22 15:14:53 +00:00
|
|
|
|
2021-04-09 12:11:37 +00:00
|
|
|
fn to_chalk(self, _db: &dyn HirDatabase) -> chalk_db::ImplId {
|
2020-07-12 13:26:02 +00:00
|
|
|
chalk_ir::ImplId(self.as_intern_id())
|
2020-05-22 15:14:53 +00:00
|
|
|
}
|
|
|
|
|
2021-04-09 12:11:37 +00:00
|
|
|
fn from_chalk(_db: &dyn HirDatabase, impl_id: chalk_db::ImplId) -> hir_def::ImplId {
|
2020-07-12 13:26:02 +00:00
|
|
|
InternKey::from_intern_id(impl_id.0)
|
2020-05-22 15:14:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-16 11:15:00 +00:00
|
|
|
impl ToChalk for CallableDefId {
|
2020-05-22 16:15:53 +00:00
|
|
|
type Chalk = FnDefId;
|
|
|
|
|
|
|
|
fn to_chalk(self, db: &dyn HirDatabase) -> FnDefId {
|
|
|
|
db.intern_callable_def(self).into()
|
|
|
|
}
|
|
|
|
|
2020-07-16 11:15:00 +00:00
|
|
|
fn from_chalk(db: &dyn HirDatabase, fn_def_id: FnDefId) -> CallableDefId {
|
2020-05-22 16:15:53 +00:00
|
|
|
db.lookup_intern_callable_def(fn_def_id.into())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-02 15:31:38 +00:00
|
|
|
pub(crate) struct TypeAliasAsValue(pub(crate) TypeAliasId);
|
2020-07-12 13:26:02 +00:00
|
|
|
|
|
|
|
impl ToChalk for TypeAliasAsValue {
|
2021-04-09 12:11:37 +00:00
|
|
|
type Chalk = chalk_db::AssociatedTyValueId;
|
2020-05-22 15:14:53 +00:00
|
|
|
|
2021-04-09 12:11:37 +00:00
|
|
|
fn to_chalk(self, _db: &dyn HirDatabase) -> chalk_db::AssociatedTyValueId {
|
2020-07-12 13:26:02 +00:00
|
|
|
rust_ir::AssociatedTyValueId(self.0.as_intern_id())
|
2020-05-22 15:14:53 +00:00
|
|
|
}
|
|
|
|
|
2020-07-12 13:26:02 +00:00
|
|
|
fn from_chalk(
|
|
|
|
_db: &dyn HirDatabase,
|
2021-04-09 12:11:37 +00:00
|
|
|
assoc_ty_value_id: chalk_db::AssociatedTyValueId,
|
2020-07-12 13:26:02 +00:00
|
|
|
) -> TypeAliasAsValue {
|
|
|
|
TypeAliasAsValue(TypeAliasId::from_intern_id(assoc_ty_value_id.0))
|
2020-05-22 15:14:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-09 12:18:58 +00:00
|
|
|
impl From<FnDefId> for crate::db::InternedCallableDefId {
|
|
|
|
fn from(fn_def_id: FnDefId) -> Self {
|
|
|
|
InternKey::from_intern_id(fn_def_id.0)
|
2020-05-22 15:14:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-09 12:18:58 +00:00
|
|
|
impl From<crate::db::InternedCallableDefId> for FnDefId {
|
|
|
|
fn from(callable_def_id: crate::db::InternedCallableDefId) -> Self {
|
|
|
|
chalk_ir::FnDefId(callable_def_id.as_intern_id())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<OpaqueTyId> for crate::db::InternedOpaqueTyId {
|
|
|
|
fn from(id: OpaqueTyId) -> Self {
|
|
|
|
InternKey::from_intern_id(id.0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<crate::db::InternedOpaqueTyId> for OpaqueTyId {
|
|
|
|
fn from(id: crate::db::InternedOpaqueTyId) -> Self {
|
|
|
|
chalk_ir::OpaqueTyId(id.as_intern_id())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<chalk_ir::ClosureId<Interner>> for crate::db::InternedClosureId {
|
|
|
|
fn from(id: chalk_ir::ClosureId<Interner>) -> Self {
|
|
|
|
Self::from_intern_id(id.0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<crate::db::InternedClosureId> for chalk_ir::ClosureId<Interner> {
|
|
|
|
fn from(id: crate::db::InternedClosureId) -> Self {
|
|
|
|
chalk_ir::ClosureId(id.as_intern_id())
|
2020-05-22 15:14:53 +00:00
|
|
|
}
|
|
|
|
}
|
2021-04-09 12:28:04 +00:00
|
|
|
|
|
|
|
pub fn to_foreign_def_id(id: TypeAliasId) -> ForeignDefId {
|
|
|
|
chalk_ir::ForeignDefId(salsa::InternKey::as_intern_id(&id))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn from_foreign_def_id(id: ForeignDefId) -> TypeAliasId {
|
|
|
|
salsa::InternKey::from_intern_id(id.0)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn to_assoc_type_id(id: TypeAliasId) -> AssocTypeId {
|
|
|
|
chalk_ir::AssocTypeId(salsa::InternKey::as_intern_id(&id))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn from_assoc_type_id(id: AssocTypeId) -> TypeAliasId {
|
|
|
|
salsa::InternKey::from_intern_id(id.0)
|
|
|
|
}
|
|
|
|
|
2021-12-29 13:35:59 +00:00
|
|
|
pub fn from_placeholder_idx(db: &dyn HirDatabase, idx: PlaceholderIndex) -> TypeOrConstParamId {
|
2021-04-09 12:28:04 +00:00
|
|
|
assert_eq!(idx.ui, chalk_ir::UniverseIndex::ROOT);
|
|
|
|
let interned_id = salsa::InternKey::from_intern_id(salsa::InternId::from(idx.idx));
|
2021-12-29 13:35:59 +00:00
|
|
|
db.lookup_intern_type_or_const_param_id(interned_id)
|
2021-04-09 12:28:04 +00:00
|
|
|
}
|
|
|
|
|
2021-12-29 13:35:59 +00:00
|
|
|
pub fn to_placeholder_idx(db: &dyn HirDatabase, id: TypeOrConstParamId) -> PlaceholderIndex {
|
|
|
|
let interned_id = db.intern_type_or_const_param_id(id);
|
2021-04-09 12:28:04 +00:00
|
|
|
PlaceholderIndex {
|
|
|
|
ui: chalk_ir::UniverseIndex::ROOT,
|
|
|
|
idx: salsa::InternKey::as_intern_id(&interned_id).as_usize(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn lt_from_placeholder_idx(db: &dyn HirDatabase, idx: PlaceholderIndex) -> LifetimeParamId {
|
|
|
|
assert_eq!(idx.ui, chalk_ir::UniverseIndex::ROOT);
|
|
|
|
let interned_id = salsa::InternKey::from_intern_id(salsa::InternId::from(idx.idx));
|
|
|
|
db.lookup_intern_lifetime_param_id(interned_id)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn to_chalk_trait_id(id: TraitId) -> ChalkTraitId {
|
|
|
|
chalk_ir::TraitId(salsa::InternKey::as_intern_id(&id))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn from_chalk_trait_id(id: ChalkTraitId) -> TraitId {
|
|
|
|
salsa::InternKey::from_intern_id(id.0)
|
|
|
|
}
|