From d719618f8e57a18006b40966253d96ec36be63cc Mon Sep 17 00:00:00 2001 From: Nathan Whitaker Date: Fri, 9 Oct 2020 19:35:53 -0400 Subject: [PATCH] Simplify program clause methods --- chalk-engine/src/logic.rs | 7 +------ chalk-recursive/src/solve.rs | 7 +------ chalk-solve/src/clauses.rs | 37 +++++++++++++++++++++--------------- 3 files changed, 24 insertions(+), 27 deletions(-) diff --git a/chalk-engine/src/logic.rs b/chalk-engine/src/logic.rs index 73e11e5044f..504f03d726e 100644 --- a/chalk-engine/src/logic.rs +++ b/chalk-engine/src/logic.rs @@ -269,12 +269,7 @@ impl Forest { }, universes: goal.universes, }; - let clauses = program_clauses_for_goal( - program, - &canon_domain_goal.canonical.value.environment, - &canon_domain_goal.canonical.value.goal, - &canon_domain_goal.canonical.binders, - ); + let clauses = program_clauses_for_goal(program, &canon_domain_goal); let (infer, subst, InEnvironment { environment, goal }) = chalk_solve::infer::InferenceTable::from_canonical( context.program().interner(), diff --git a/chalk-recursive/src/solve.rs b/chalk-recursive/src/solve.rs index fc3584abfda..7fdf725dd42 100644 --- a/chalk-recursive/src/solve.rs +++ b/chalk-recursive/src/solve.rs @@ -205,12 +205,7 @@ trait SolveIterationHelpers: SolveDatabase { &self, canonical_goal: &UCanonical>>, ) -> Result>, Floundered> { - program_clauses_for_goal( - self.db(), - &canonical_goal.canonical.value.environment, - &canonical_goal.canonical.value.goal, - &canonical_goal.canonical.binders, - ) + program_clauses_for_goal(self.db(), &canonical_goal) } } diff --git a/chalk-solve/src/clauses.rs b/chalk-solve/src/clauses.rs index a9080ef4efc..2487c3586c7 100644 --- a/chalk-solve/src/clauses.rs +++ b/chalk-solve/src/clauses.rs @@ -344,24 +344,28 @@ pub fn push_auto_trait_impls_generator_witness( #[instrument(level = "debug", skip(db))] pub fn program_clauses_for_goal<'db, I: Interner>( db: &'db dyn RustIrDatabase, - environment: &Environment, - goal: &DomainGoal, - binders: &CanonicalVarKinds, + goal: &UCanonical>>, ) -> Result>, Floundered> { let interner = db.interner(); let custom_clauses = db.custom_clauses().into_iter(); - let clauses_that_could_match = program_clauses_that_could_match(db, environment, goal, binders) - .map(|cl| cl.into_iter())?; + let clauses_that_could_match = + program_clauses_that_could_match(db, goal).map(|cl| cl.into_iter())?; let clauses: Vec> = custom_clauses .chain(clauses_that_could_match) .chain( - db.program_clauses_for_env(environment) + db.program_clauses_for_env(&goal.canonical.value.environment) .iter(interner) .cloned(), ) - .filter(|c| c.could_match(interner, db.unification_database(), goal)) + .filter(|c| { + c.could_match( + interner, + db.unification_database(), + &goal.canonical.value.goal, + ) + }) .collect(); debug!(?clauses); @@ -373,21 +377,24 @@ pub fn program_clauses_for_goal<'db, I: Interner>( /// `goal`. This can be any superset of the correct set, but the /// more precise you can make it, the more efficient solving will /// be. -#[instrument(level = "debug", skip(db, environment))] +#[instrument(level = "debug", skip(db))] fn program_clauses_that_could_match( db: &dyn RustIrDatabase, - environment: &Environment, - goal: &DomainGoal, - // FIXME: These are the binders for `goal`. We're passing them separately - // because `goal` is not necessarily canonicalized: The recursive solver - // passes the canonical goal; the SLG solver instantiates the goal first. - // (See #568.) - binders: &CanonicalVarKinds, + goal: &UCanonical>>, ) -> Result>, Floundered> { let interner = db.interner(); let mut clauses: Vec> = vec![]; let builder = &mut ClauseBuilder::new(db, &mut clauses); + let UCanonical { + canonical: + Canonical { + value: InEnvironment { environment, goal }, + binders, + }, + universes: _, + } = goal; + match goal { DomainGoal::Holds(WhereClause::Implemented(trait_ref)) => { let self_ty = trait_ref.self_type_parameter(interner);