mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-26 13:03:31 +00:00
Update Chalk, and cache Chalk env elaboration through a query
This should fix some of the worst performance problems.
This commit is contained in:
parent
2e0b7b0159
commit
0be68a4825
6 changed files with 171 additions and 36 deletions
12
Cargo.lock
generated
12
Cargo.lock
generated
|
@ -114,7 +114,7 @@ checksum = "4785bdd1c96b2a846b2bd7cc02e86b6b3dbf14e7e53446c4f54c92a361040822"
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chalk-derive"
|
name = "chalk-derive"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/rust-lang/chalk.git?rev=28cef6ff403d403e6ad2f3d27d944e9ffac1bce8#28cef6ff403d403e6ad2f3d27d944e9ffac1bce8"
|
source = "git+https://github.com/rust-lang/chalk.git?rev=2c072cc830d04af5f10b390e6643327f85108282#2c072cc830d04af5f10b390e6643327f85108282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
|
@ -125,7 +125,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chalk-engine"
|
name = "chalk-engine"
|
||||||
version = "0.9.0"
|
version = "0.9.0"
|
||||||
source = "git+https://github.com/rust-lang/chalk.git?rev=28cef6ff403d403e6ad2f3d27d944e9ffac1bce8#28cef6ff403d403e6ad2f3d27d944e9ffac1bce8"
|
source = "git+https://github.com/rust-lang/chalk.git?rev=2c072cc830d04af5f10b390e6643327f85108282#2c072cc830d04af5f10b390e6643327f85108282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"chalk-macros",
|
"chalk-macros",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -134,7 +134,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chalk-ir"
|
name = "chalk-ir"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/rust-lang/chalk.git?rev=28cef6ff403d403e6ad2f3d27d944e9ffac1bce8#28cef6ff403d403e6ad2f3d27d944e9ffac1bce8"
|
source = "git+https://github.com/rust-lang/chalk.git?rev=2c072cc830d04af5f10b390e6643327f85108282#2c072cc830d04af5f10b390e6643327f85108282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"chalk-derive",
|
"chalk-derive",
|
||||||
"chalk-engine",
|
"chalk-engine",
|
||||||
|
@ -144,7 +144,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chalk-macros"
|
name = "chalk-macros"
|
||||||
version = "0.1.1"
|
version = "0.1.1"
|
||||||
source = "git+https://github.com/rust-lang/chalk.git?rev=28cef6ff403d403e6ad2f3d27d944e9ffac1bce8#28cef6ff403d403e6ad2f3d27d944e9ffac1bce8"
|
source = "git+https://github.com/rust-lang/chalk.git?rev=2c072cc830d04af5f10b390e6643327f85108282#2c072cc830d04af5f10b390e6643327f85108282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"lazy_static",
|
"lazy_static",
|
||||||
]
|
]
|
||||||
|
@ -152,7 +152,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chalk-rust-ir"
|
name = "chalk-rust-ir"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/rust-lang/chalk.git?rev=28cef6ff403d403e6ad2f3d27d944e9ffac1bce8#28cef6ff403d403e6ad2f3d27d944e9ffac1bce8"
|
source = "git+https://github.com/rust-lang/chalk.git?rev=2c072cc830d04af5f10b390e6643327f85108282#2c072cc830d04af5f10b390e6643327f85108282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"chalk-derive",
|
"chalk-derive",
|
||||||
"chalk-engine",
|
"chalk-engine",
|
||||||
|
@ -163,7 +163,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "chalk-solve"
|
name = "chalk-solve"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/rust-lang/chalk.git?rev=28cef6ff403d403e6ad2f3d27d944e9ffac1bce8#28cef6ff403d403e6ad2f3d27d944e9ffac1bce8"
|
source = "git+https://github.com/rust-lang/chalk.git?rev=2c072cc830d04af5f10b390e6643327f85108282#2c072cc830d04af5f10b390e6643327f85108282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"chalk-derive",
|
"chalk-derive",
|
||||||
"chalk-engine",
|
"chalk-engine",
|
||||||
|
|
|
@ -27,9 +27,9 @@ test_utils = { path = "../test_utils" }
|
||||||
|
|
||||||
scoped-tls = "1"
|
scoped-tls = "1"
|
||||||
|
|
||||||
chalk-solve = { git = "https://github.com/rust-lang/chalk.git", rev = "28cef6ff403d403e6ad2f3d27d944e9ffac1bce8" }
|
chalk-solve = { git = "https://github.com/rust-lang/chalk.git", rev = "2c072cc830d04af5f10b390e6643327f85108282" }
|
||||||
chalk-rust-ir = { git = "https://github.com/rust-lang/chalk.git", rev = "28cef6ff403d403e6ad2f3d27d944e9ffac1bce8" }
|
chalk-rust-ir = { git = "https://github.com/rust-lang/chalk.git", rev = "2c072cc830d04af5f10b390e6643327f85108282" }
|
||||||
chalk-ir = { git = "https://github.com/rust-lang/chalk.git", rev = "28cef6ff403d403e6ad2f3d27d944e9ffac1bce8" }
|
chalk-ir = { git = "https://github.com/rust-lang/chalk.git", rev = "2c072cc830d04af5f10b390e6643327f85108282" }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
insta = "0.16.0"
|
insta = "0.16.0"
|
||||||
|
|
|
@ -107,6 +107,13 @@ pub trait HirDatabase: DefDatabase + Upcast<dyn DefDatabase> {
|
||||||
krate: CrateId,
|
krate: CrateId,
|
||||||
goal: crate::Canonical<crate::InEnvironment<crate::Obligation>>,
|
goal: crate::Canonical<crate::InEnvironment<crate::Obligation>>,
|
||||||
) -> Option<crate::traits::Solution>;
|
) -> Option<crate::traits::Solution>;
|
||||||
|
|
||||||
|
#[salsa::invoke(crate::traits::chalk::program_clauses_for_chalk_env_query)]
|
||||||
|
fn program_clauses_for_chalk_env(
|
||||||
|
&self,
|
||||||
|
krate: CrateId,
|
||||||
|
env: chalk_ir::Environment<chalk::Interner>,
|
||||||
|
) -> chalk_ir::ProgramClauses<chalk::Interner>;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn infer_wait(db: &impl HirDatabase, def: DefWithBodyId) -> Arc<InferenceResult> {
|
fn infer_wait(db: &impl HirDatabase, def: DefWithBodyId) -> Arc<InferenceResult> {
|
||||||
|
|
|
@ -225,7 +225,7 @@ fn solution_from_chalk(
|
||||||
None => unimplemented!(),
|
None => unimplemented!(),
|
||||||
})
|
})
|
||||||
.collect();
|
.collect();
|
||||||
let result = Canonical { value, num_vars: subst.binders.len() };
|
let result = Canonical { value, num_vars: subst.binders.len(&Interner) };
|
||||||
SolutionVariables(result)
|
SolutionVariables(result)
|
||||||
};
|
};
|
||||||
match solution {
|
match solution {
|
||||||
|
|
|
@ -4,8 +4,8 @@ use std::{fmt, sync::Arc};
|
||||||
use log::debug;
|
use log::debug;
|
||||||
|
|
||||||
use chalk_ir::{
|
use chalk_ir::{
|
||||||
cast::Cast, fold::shift::Shift, Goal, GoalData, Parameter, PlaceholderIndex, TypeName,
|
cast::Cast, fold::shift::Shift, interner::HasInterner, Goal, GoalData, Parameter,
|
||||||
UniverseIndex,
|
PlaceholderIndex, TypeName, UniverseIndex,
|
||||||
};
|
};
|
||||||
|
|
||||||
use hir_def::{AssocContainerId, AssocItemId, GenericDefId, HasModule, Lookup, TypeAliasId};
|
use hir_def::{AssocContainerId, AssocItemId, GenericDefId, HasModule, Lookup, TypeAliasId};
|
||||||
|
@ -33,8 +33,10 @@ impl chalk_ir::interner::Interner for Interner {
|
||||||
type InternedGoals = Vec<Goal<Self>>;
|
type InternedGoals = Vec<Goal<Self>>;
|
||||||
type InternedSubstitution = Vec<Parameter<Self>>;
|
type InternedSubstitution = Vec<Parameter<Self>>;
|
||||||
type InternedProgramClause = chalk_ir::ProgramClauseData<Self>;
|
type InternedProgramClause = chalk_ir::ProgramClauseData<Self>;
|
||||||
type InternedProgramClauses = Vec<chalk_ir::ProgramClause<Self>>;
|
type InternedProgramClauses = Arc<[chalk_ir::ProgramClause<Self>]>;
|
||||||
type InternedQuantifiedWhereClauses = Vec<chalk_ir::QuantifiedWhereClause<Self>>;
|
type InternedQuantifiedWhereClauses = Vec<chalk_ir::QuantifiedWhereClause<Self>>;
|
||||||
|
type InternedParameterKinds = Vec<chalk_ir::ParameterKind<()>>;
|
||||||
|
type InternedCanonicalVarKinds = Vec<chalk_ir::ParameterKind<UniverseIndex>>;
|
||||||
type Identifier = TypeAliasId;
|
type Identifier = TypeAliasId;
|
||||||
type DefId = InternId;
|
type DefId = InternId;
|
||||||
|
|
||||||
|
@ -60,6 +62,27 @@ impl chalk_ir::interner::Interner for Interner {
|
||||||
tls::with_current_program(|prog| Some(prog?.debug_alias(alias, fmt)))
|
tls::with_current_program(|prog| Some(prog?.debug_alias(alias, fmt)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn debug_projection_ty(
|
||||||
|
proj: &chalk_ir::ProjectionTy<Interner>,
|
||||||
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
|
) -> Option<fmt::Result> {
|
||||||
|
tls::with_current_program(|prog| Some(prog?.debug_projection_ty(proj, fmt)))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn debug_opaque_ty(
|
||||||
|
opaque_ty: &chalk_ir::OpaqueTy<Interner>,
|
||||||
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
|
) -> Option<fmt::Result> {
|
||||||
|
tls::with_current_program(|prog| Some(prog?.debug_opaque_ty(opaque_ty, fmt)))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn debug_opaque_ty_id(
|
||||||
|
opaque_ty_id: chalk_ir::OpaqueTyId<Self>,
|
||||||
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
|
) -> Option<fmt::Result> {
|
||||||
|
tls::with_current_program(|prog| Some(prog?.debug_opaque_ty_id(opaque_ty_id, fmt)))
|
||||||
|
}
|
||||||
|
|
||||||
fn debug_ty(ty: &chalk_ir::Ty<Interner>, fmt: &mut fmt::Formatter<'_>) -> Option<fmt::Result> {
|
fn debug_ty(ty: &chalk_ir::Ty<Interner>, fmt: &mut fmt::Formatter<'_>) -> Option<fmt::Result> {
|
||||||
tls::with_current_program(|prog| Some(prog?.debug_ty(ty, fmt)))
|
tls::with_current_program(|prog| Some(prog?.debug_ty(ty, fmt)))
|
||||||
}
|
}
|
||||||
|
@ -202,15 +225,15 @@ impl chalk_ir::interner::Interner for Interner {
|
||||||
fn intern_program_clauses(
|
fn intern_program_clauses(
|
||||||
&self,
|
&self,
|
||||||
data: impl IntoIterator<Item = chalk_ir::ProgramClause<Self>>,
|
data: impl IntoIterator<Item = chalk_ir::ProgramClause<Self>>,
|
||||||
) -> Vec<chalk_ir::ProgramClause<Self>> {
|
) -> Arc<[chalk_ir::ProgramClause<Self>]> {
|
||||||
data.into_iter().collect()
|
data.into_iter().collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn program_clauses_data<'a>(
|
fn program_clauses_data<'a>(
|
||||||
&self,
|
&self,
|
||||||
clauses: &'a Vec<chalk_ir::ProgramClause<Self>>,
|
clauses: &'a Arc<[chalk_ir::ProgramClause<Self>]>,
|
||||||
) -> &'a [chalk_ir::ProgramClause<Self>] {
|
) -> &'a [chalk_ir::ProgramClause<Self>] {
|
||||||
clauses
|
&clauses
|
||||||
}
|
}
|
||||||
|
|
||||||
fn intern_quantified_where_clauses(
|
fn intern_quantified_where_clauses(
|
||||||
|
@ -226,6 +249,34 @@ impl chalk_ir::interner::Interner for Interner {
|
||||||
) -> &'a [chalk_ir::QuantifiedWhereClause<Self>] {
|
) -> &'a [chalk_ir::QuantifiedWhereClause<Self>] {
|
||||||
clauses
|
clauses
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn intern_parameter_kinds(
|
||||||
|
&self,
|
||||||
|
data: impl IntoIterator<Item = chalk_ir::ParameterKind<()>>,
|
||||||
|
) -> Self::InternedParameterKinds {
|
||||||
|
data.into_iter().collect()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn parameter_kinds_data<'a>(
|
||||||
|
&self,
|
||||||
|
parameter_kinds: &'a Self::InternedParameterKinds,
|
||||||
|
) -> &'a [chalk_ir::ParameterKind<()>] {
|
||||||
|
¶meter_kinds
|
||||||
|
}
|
||||||
|
|
||||||
|
fn intern_canonical_var_kinds(
|
||||||
|
&self,
|
||||||
|
data: impl IntoIterator<Item = chalk_ir::ParameterKind<UniverseIndex>>,
|
||||||
|
) -> Self::InternedCanonicalVarKinds {
|
||||||
|
data.into_iter().collect()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn canonical_var_kinds_data<'a>(
|
||||||
|
&self,
|
||||||
|
canonical_var_kinds: &'a Self::InternedCanonicalVarKinds,
|
||||||
|
) -> &'a [chalk_ir::ParameterKind<UniverseIndex>] {
|
||||||
|
&canonical_var_kinds
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl chalk_ir::interner::HasInterner for Interner {
|
impl chalk_ir::interner::HasInterner for Interner {
|
||||||
|
@ -268,9 +319,12 @@ impl ToChalk for Ty {
|
||||||
Ty::Projection(proj_ty) => {
|
Ty::Projection(proj_ty) => {
|
||||||
let associated_ty_id = proj_ty.associated_ty.to_chalk(db);
|
let associated_ty_id = proj_ty.associated_ty.to_chalk(db);
|
||||||
let substitution = proj_ty.parameters.to_chalk(db);
|
let substitution = proj_ty.parameters.to_chalk(db);
|
||||||
chalk_ir::AliasTy { associated_ty_id, substitution }
|
chalk_ir::AliasTy::Projection(chalk_ir::ProjectionTy {
|
||||||
.cast(&Interner)
|
associated_ty_id,
|
||||||
.intern(&Interner)
|
substitution,
|
||||||
|
})
|
||||||
|
.cast(&Interner)
|
||||||
|
.intern(&Interner)
|
||||||
}
|
}
|
||||||
Ty::Placeholder(id) => {
|
Ty::Placeholder(id) => {
|
||||||
let interned_id = db.intern_type_param_id(id);
|
let interned_id = db.intern_type_param_id(id);
|
||||||
|
@ -314,16 +368,17 @@ impl ToChalk for Ty {
|
||||||
);
|
);
|
||||||
Ty::Placeholder(db.lookup_intern_type_param_id(interned_id))
|
Ty::Placeholder(db.lookup_intern_type_param_id(interned_id))
|
||||||
}
|
}
|
||||||
chalk_ir::TyData::Alias(proj) => {
|
chalk_ir::TyData::Alias(chalk_ir::AliasTy::Projection(proj)) => {
|
||||||
let associated_ty = from_chalk(db, proj.associated_ty_id);
|
let associated_ty = from_chalk(db, proj.associated_ty_id);
|
||||||
let parameters = from_chalk(db, proj.substitution);
|
let parameters = from_chalk(db, proj.substitution);
|
||||||
Ty::Projection(ProjectionTy { associated_ty, parameters })
|
Ty::Projection(ProjectionTy { associated_ty, parameters })
|
||||||
}
|
}
|
||||||
|
chalk_ir::TyData::Alias(chalk_ir::AliasTy::Opaque(_)) => unimplemented!(),
|
||||||
chalk_ir::TyData::Function(_) => unimplemented!(),
|
chalk_ir::TyData::Function(_) => unimplemented!(),
|
||||||
chalk_ir::TyData::BoundVar(idx) => Ty::Bound(idx),
|
chalk_ir::TyData::BoundVar(idx) => Ty::Bound(idx),
|
||||||
chalk_ir::TyData::InferenceVar(_iv) => Ty::Unknown,
|
chalk_ir::TyData::InferenceVar(_iv) => Ty::Unknown,
|
||||||
chalk_ir::TyData::Dyn(where_clauses) => {
|
chalk_ir::TyData::Dyn(where_clauses) => {
|
||||||
assert_eq!(where_clauses.bounds.binders.len(), 1);
|
assert_eq!(where_clauses.bounds.binders.len(&Interner), 1);
|
||||||
let predicates = where_clauses
|
let predicates = where_clauses
|
||||||
.bounds
|
.bounds
|
||||||
.skip_binders()
|
.skip_binders()
|
||||||
|
@ -404,6 +459,7 @@ impl ToChalk for TypeCtor {
|
||||||
match type_name {
|
match type_name {
|
||||||
TypeName::Struct(struct_id) => db.lookup_intern_type_ctor(struct_id.into()),
|
TypeName::Struct(struct_id) => db.lookup_intern_type_ctor(struct_id.into()),
|
||||||
TypeName::AssociatedType(type_id) => TypeCtor::AssociatedType(from_chalk(db, type_id)),
|
TypeName::AssociatedType(type_id) => TypeCtor::AssociatedType(from_chalk(db, type_id)),
|
||||||
|
TypeName::OpaqueType(_) => unreachable!(),
|
||||||
TypeName::Error => {
|
TypeName::Error => {
|
||||||
// this should not be reached, since we don't represent TypeName::Error with TypeCtor
|
// this should not be reached, since we don't represent TypeName::Error with TypeCtor
|
||||||
unreachable!()
|
unreachable!()
|
||||||
|
@ -460,7 +516,8 @@ impl ToChalk for GenericPredicate {
|
||||||
}
|
}
|
||||||
GenericPredicate::Projection(projection_pred) => {
|
GenericPredicate::Projection(projection_pred) => {
|
||||||
let ty = projection_pred.ty.to_chalk(db).shifted_in(&Interner);
|
let ty = projection_pred.ty.to_chalk(db).shifted_in(&Interner);
|
||||||
let alias = projection_pred.projection_ty.to_chalk(db).shifted_in(&Interner);
|
let projection = projection_pred.projection_ty.to_chalk(db).shifted_in(&Interner);
|
||||||
|
let alias = chalk_ir::AliasTy::Projection(projection);
|
||||||
make_binders(chalk_ir::WhereClause::AliasEq(chalk_ir::AliasEq { alias, ty }), 0)
|
make_binders(chalk_ir::WhereClause::AliasEq(chalk_ir::AliasEq { alias, ty }), 0)
|
||||||
}
|
}
|
||||||
GenericPredicate::Error => panic!("tried passing GenericPredicate::Error to Chalk"),
|
GenericPredicate::Error => panic!("tried passing GenericPredicate::Error to Chalk"),
|
||||||
|
@ -481,7 +538,13 @@ impl ToChalk for GenericPredicate {
|
||||||
GenericPredicate::Implemented(from_chalk(db, tr))
|
GenericPredicate::Implemented(from_chalk(db, tr))
|
||||||
}
|
}
|
||||||
chalk_ir::WhereClause::AliasEq(projection_eq) => {
|
chalk_ir::WhereClause::AliasEq(projection_eq) => {
|
||||||
let projection_ty = from_chalk(db, projection_eq.alias);
|
let projection_ty = from_chalk(
|
||||||
|
db,
|
||||||
|
match projection_eq.alias {
|
||||||
|
chalk_ir::AliasTy::Projection(p) => p,
|
||||||
|
_ => unimplemented!(),
|
||||||
|
},
|
||||||
|
);
|
||||||
let ty = from_chalk(db, projection_eq.ty);
|
let ty = from_chalk(db, projection_eq.ty);
|
||||||
GenericPredicate::Projection(super::ProjectionPredicate { projection_ty, ty })
|
GenericPredicate::Projection(super::ProjectionPredicate { projection_ty, ty })
|
||||||
}
|
}
|
||||||
|
@ -490,10 +553,10 @@ impl ToChalk for GenericPredicate {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ToChalk for ProjectionTy {
|
impl ToChalk for ProjectionTy {
|
||||||
type Chalk = chalk_ir::AliasTy<Interner>;
|
type Chalk = chalk_ir::ProjectionTy<Interner>;
|
||||||
|
|
||||||
fn to_chalk(self, db: &dyn HirDatabase) -> chalk_ir::AliasTy<Interner> {
|
fn to_chalk(self, db: &dyn HirDatabase) -> chalk_ir::ProjectionTy<Interner> {
|
||||||
chalk_ir::AliasTy {
|
chalk_ir::ProjectionTy {
|
||||||
associated_ty_id: self.associated_ty.to_chalk(db),
|
associated_ty_id: self.associated_ty.to_chalk(db),
|
||||||
substitution: self.parameters.to_chalk(db),
|
substitution: self.parameters.to_chalk(db),
|
||||||
}
|
}
|
||||||
|
@ -501,7 +564,7 @@ impl ToChalk for ProjectionTy {
|
||||||
|
|
||||||
fn from_chalk(
|
fn from_chalk(
|
||||||
db: &dyn HirDatabase,
|
db: &dyn HirDatabase,
|
||||||
projection_ty: chalk_ir::AliasTy<Interner>,
|
projection_ty: chalk_ir::ProjectionTy<Interner>,
|
||||||
) -> ProjectionTy {
|
) -> ProjectionTy {
|
||||||
ProjectionTy {
|
ProjectionTy {
|
||||||
associated_ty: from_chalk(db, projection_ty.associated_ty_id),
|
associated_ty: from_chalk(db, projection_ty.associated_ty_id),
|
||||||
|
@ -514,7 +577,10 @@ impl ToChalk for super::ProjectionPredicate {
|
||||||
type Chalk = chalk_ir::AliasEq<Interner>;
|
type Chalk = chalk_ir::AliasEq<Interner>;
|
||||||
|
|
||||||
fn to_chalk(self, db: &dyn HirDatabase) -> chalk_ir::AliasEq<Interner> {
|
fn to_chalk(self, db: &dyn HirDatabase) -> chalk_ir::AliasEq<Interner> {
|
||||||
chalk_ir::AliasEq { alias: self.projection_ty.to_chalk(db), ty: self.ty.to_chalk(db) }
|
chalk_ir::AliasEq {
|
||||||
|
alias: chalk_ir::AliasTy::Projection(self.projection_ty.to_chalk(db)),
|
||||||
|
ty: self.ty.to_chalk(db),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn from_chalk(_db: &dyn HirDatabase, _normalize: chalk_ir::AliasEq<Interner>) -> Self {
|
fn from_chalk(_db: &dyn HirDatabase, _normalize: chalk_ir::AliasEq<Interner>) -> Self {
|
||||||
|
@ -540,17 +606,24 @@ impl ToChalk for Obligation {
|
||||||
impl<T> ToChalk for Canonical<T>
|
impl<T> ToChalk for Canonical<T>
|
||||||
where
|
where
|
||||||
T: ToChalk,
|
T: ToChalk,
|
||||||
|
T::Chalk: HasInterner<Interner = Interner>,
|
||||||
{
|
{
|
||||||
type Chalk = chalk_ir::Canonical<T::Chalk>;
|
type Chalk = chalk_ir::Canonical<T::Chalk>;
|
||||||
|
|
||||||
fn to_chalk(self, db: &dyn HirDatabase) -> chalk_ir::Canonical<T::Chalk> {
|
fn to_chalk(self, db: &dyn HirDatabase) -> chalk_ir::Canonical<T::Chalk> {
|
||||||
let parameter = chalk_ir::ParameterKind::Ty(chalk_ir::UniverseIndex::ROOT);
|
let parameter = chalk_ir::ParameterKind::Ty(chalk_ir::UniverseIndex::ROOT);
|
||||||
let value = self.value.to_chalk(db);
|
let value = self.value.to_chalk(db);
|
||||||
chalk_ir::Canonical { value, binders: vec![parameter; self.num_vars] }
|
chalk_ir::Canonical {
|
||||||
|
value,
|
||||||
|
binders: chalk_ir::CanonicalVarKinds::from(&Interner, vec![parameter; self.num_vars]),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn from_chalk(db: &dyn HirDatabase, canonical: chalk_ir::Canonical<T::Chalk>) -> Canonical<T> {
|
fn from_chalk(db: &dyn HirDatabase, canonical: chalk_ir::Canonical<T::Chalk>) -> Canonical<T> {
|
||||||
Canonical { num_vars: canonical.binders.len(), value: from_chalk(db, canonical.value) }
|
Canonical {
|
||||||
|
num_vars: canonical.binders.len(&Interner),
|
||||||
|
value: from_chalk(db, canonical.value),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -649,9 +722,15 @@ impl ToChalk for builtin::BuiltinImplAssocTyValueData {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn make_binders<T>(value: T, num_vars: usize) -> chalk_ir::Binders<T> {
|
fn make_binders<T>(value: T, num_vars: usize) -> chalk_ir::Binders<T>
|
||||||
|
where
|
||||||
|
T: HasInterner<Interner = Interner>,
|
||||||
|
{
|
||||||
chalk_ir::Binders::new(
|
chalk_ir::Binders::new(
|
||||||
std::iter::repeat(chalk_ir::ParameterKind::Ty(())).take(num_vars).collect(),
|
chalk_ir::ParameterKinds::from(
|
||||||
|
&Interner,
|
||||||
|
std::iter::repeat(chalk_ir::ParameterKind::Ty(())).take(num_vars),
|
||||||
|
),
|
||||||
value,
|
value,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -799,6 +878,28 @@ impl<'a> chalk_solve::RustIrDatabase<Interner> for ChalkContext<'a> {
|
||||||
// FIXME tell Chalk about well-known traits (here and in trait_datum)
|
// FIXME tell Chalk about well-known traits (here and in trait_datum)
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn program_clauses_for_env(
|
||||||
|
&self,
|
||||||
|
environment: &chalk_ir::Environment<Interner>,
|
||||||
|
) -> chalk_ir::ProgramClauses<Interner> {
|
||||||
|
self.db.program_clauses_for_chalk_env(self.krate, environment.clone())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn opaque_ty_data(
|
||||||
|
&self,
|
||||||
|
_id: chalk_ir::OpaqueTyId<Interner>,
|
||||||
|
) -> Arc<chalk_rust_ir::OpaqueTyDatum<Interner>> {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) fn program_clauses_for_chalk_env_query(
|
||||||
|
db: &dyn HirDatabase,
|
||||||
|
krate: CrateId,
|
||||||
|
environment: chalk_ir::Environment<Interner>,
|
||||||
|
) -> chalk_ir::ProgramClauses<Interner> {
|
||||||
|
chalk_solve::program_clauses_for_env(&ChalkContext { db, krate }, &environment)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn associated_ty_data_query(
|
pub(crate) fn associated_ty_data_query(
|
||||||
|
|
|
@ -121,19 +121,38 @@ impl DebugContext<'_> {
|
||||||
write!(fmt, "{}::{}", trait_data.name, type_alias_data.name)
|
write!(fmt, "{}::{}", trait_data.name, type_alias_data.name)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn debug_alias(
|
pub fn debug_opaque_ty_id(
|
||||||
&self,
|
&self,
|
||||||
alias: &AliasTy<Interner>,
|
opaque_ty_id: chalk_ir::OpaqueTyId<Interner>,
|
||||||
fmt: &mut fmt::Formatter<'_>,
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
) -> Result<(), fmt::Error> {
|
) -> Result<(), fmt::Error> {
|
||||||
let type_alias: TypeAliasId = from_chalk(self.0, alias.associated_ty_id);
|
fmt.debug_struct("OpaqueTyId").field("index", &opaque_ty_id.0).finish()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn debug_alias(
|
||||||
|
&self,
|
||||||
|
alias_ty: &AliasTy<Interner>,
|
||||||
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
|
) -> Result<(), fmt::Error> {
|
||||||
|
match alias_ty {
|
||||||
|
AliasTy::Projection(projection_ty) => self.debug_projection_ty(projection_ty, fmt),
|
||||||
|
AliasTy::Opaque(opaque_ty) => self.debug_opaque_ty(opaque_ty, fmt),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn debug_projection_ty(
|
||||||
|
&self,
|
||||||
|
projection_ty: &chalk_ir::ProjectionTy<Interner>,
|
||||||
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
|
) -> Result<(), fmt::Error> {
|
||||||
|
let type_alias: TypeAliasId = from_chalk(self.0, projection_ty.associated_ty_id);
|
||||||
let type_alias_data = self.0.type_alias_data(type_alias);
|
let type_alias_data = self.0.type_alias_data(type_alias);
|
||||||
let trait_ = match type_alias.lookup(self.0.upcast()).container {
|
let trait_ = match type_alias.lookup(self.0.upcast()).container {
|
||||||
AssocContainerId::TraitId(t) => t,
|
AssocContainerId::TraitId(t) => t,
|
||||||
_ => panic!("associated type not in trait"),
|
_ => panic!("associated type not in trait"),
|
||||||
};
|
};
|
||||||
let trait_data = self.0.trait_data(trait_);
|
let trait_data = self.0.trait_data(trait_);
|
||||||
let params = alias.substitution.parameters(&Interner);
|
let params = projection_ty.substitution.parameters(&Interner);
|
||||||
write!(fmt, "<{:?} as {}", ¶ms[0], trait_data.name,)?;
|
write!(fmt, "<{:?} as {}", ¶ms[0], trait_data.name,)?;
|
||||||
if params.len() > 1 {
|
if params.len() > 1 {
|
||||||
write!(
|
write!(
|
||||||
|
@ -145,6 +164,14 @@ impl DebugContext<'_> {
|
||||||
write!(fmt, ">::{}", type_alias_data.name)
|
write!(fmt, ">::{}", type_alias_data.name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn debug_opaque_ty(
|
||||||
|
&self,
|
||||||
|
opaque_ty: &chalk_ir::OpaqueTy<Interner>,
|
||||||
|
fmt: &mut fmt::Formatter<'_>,
|
||||||
|
) -> Result<(), fmt::Error> {
|
||||||
|
write!(fmt, "{:?}", opaque_ty.opaque_ty_id)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn debug_ty(
|
pub fn debug_ty(
|
||||||
&self,
|
&self,
|
||||||
ty: &chalk_ir::Ty<Interner>,
|
ty: &chalk_ir::Ty<Interner>,
|
||||||
|
|
Loading…
Reference in a new issue