|
1 | 1 | use super::program_clauses::ToProgramClauses; |
2 | 2 | use crate::clauses::builder::ClauseBuilder; |
3 | 3 | use crate::clauses::{match_alias_ty, match_ty}; |
| 4 | +use crate::AliasEq; |
4 | 5 | use crate::DomainGoal; |
5 | 6 | use crate::FromEnv; |
6 | 7 | use crate::ProgramClause; |
7 | 8 | use crate::RustIrDatabase; |
8 | 9 | use crate::Ty; |
9 | | -use crate::{debug_span, TyKind}; |
| 10 | +use crate::WhereClause; |
| 11 | +use crate::{debug_span, TyData}; |
10 | 12 | use chalk_ir::interner::Interner; |
11 | 13 | use chalk_ir::visit::{Visit, Visitor}; |
12 | 14 | use chalk_ir::{DebruijnIndex, Environment}; |
@@ -87,25 +89,32 @@ impl<'me, I: Interner> Visitor<'me, I> for EnvElaborator<'me, I> { |
87 | 89 | } |
88 | 90 |
|
89 | 91 | fn visit_domain_goal(&mut self, domain_goal: &DomainGoal<I>, outer_binder: DebruijnIndex) { |
90 | | - if let DomainGoal::FromEnv(from_env) = domain_goal { |
91 | | - debug_span!("visit_domain_goal", ?from_env); |
92 | | - match from_env { |
93 | | - FromEnv::Trait(trait_ref) => { |
94 | | - let trait_datum = self.db.trait_datum(trait_ref.trait_id); |
| 92 | + match domain_goal { |
| 93 | + DomainGoal::FromEnv(from_env) => { |
| 94 | + debug_span!("visit_domain_goal", ?from_env); |
| 95 | + match from_env { |
| 96 | + FromEnv::Trait(trait_ref) => { |
| 97 | + let trait_datum = self.db.trait_datum(trait_ref.trait_id); |
95 | 98 |
|
96 | | - trait_datum.to_program_clauses(&mut self.builder, self.environment); |
| 99 | + trait_datum.to_program_clauses(&mut self.builder, self.environment); |
97 | 100 |
|
98 | | - // If we know that `T: Iterator`, then we also know |
99 | | - // things about `<T as Iterator>::Item`, so push those |
100 | | - // implied bounds too: |
101 | | - for &associated_ty_id in &trait_datum.associated_ty_ids { |
102 | | - self.db |
103 | | - .associated_ty_data(associated_ty_id) |
104 | | - .to_program_clauses(&mut self.builder, self.environment); |
| 101 | + // If we know that `T: Iterator`, then we also know |
| 102 | + // things about `<T as Iterator>::Item`, so push those |
| 103 | + // implied bounds too: |
| 104 | + for &associated_ty_id in &trait_datum.associated_ty_ids { |
| 105 | + self.db |
| 106 | + .associated_ty_data(associated_ty_id) |
| 107 | + .to_program_clauses(&mut self.builder, self.environment); |
| 108 | + } |
105 | 109 | } |
| 110 | + FromEnv::Ty(ty) => ty.visit_with(self, outer_binder), |
106 | 111 | } |
107 | | - FromEnv::Ty(ty) => ty.visit_with(self, outer_binder), |
108 | 112 | } |
| 113 | + DomainGoal::Holds(WhereClause::AliasEq(AliasEq { alias, ty })) => { |
| 114 | + match_alias_ty(&mut self.builder, self.environment, alias); |
| 115 | + ty.visit_with(self, outer_binder); |
| 116 | + } |
| 117 | + _ => {} |
109 | 118 | } |
110 | 119 | } |
111 | 120 | } |
0 commit comments