aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_hir/src
diff options
context:
space:
mode:
Diffstat (limited to 'crates/ra_hir/src')
-rw-r--r--crates/ra_hir/src/ty/lower.rs35
1 files changed, 15 insertions, 20 deletions
diff --git a/crates/ra_hir/src/ty/lower.rs b/crates/ra_hir/src/ty/lower.rs
index 5dce2f342..2d447f1ea 100644
--- a/crates/ra_hir/src/ty/lower.rs
+++ b/crates/ra_hir/src/ty/lower.rs
@@ -31,7 +31,6 @@ use crate::{
31 utils::{all_super_traits, associated_type_by_name_including_super_traits, variant_data}, 31 utils::{all_super_traits, associated_type_by_name_including_super_traits, variant_data},
32 }, 32 },
33 util::make_mut_slice, 33 util::make_mut_slice,
34 ImplBlock, Trait,
35}; 34};
36 35
37impl Ty { 36impl Ty {
@@ -148,13 +147,8 @@ impl Ty {
148 ) -> Ty { 147 ) -> Ty {
149 let ty = match resolution { 148 let ty = match resolution {
150 TypeNs::TraitId(trait_) => { 149 TypeNs::TraitId(trait_) => {
151 let trait_ref = TraitRef::from_resolved_path( 150 let trait_ref =
152 db, 151 TraitRef::from_resolved_path(db, resolver, trait_, resolved_segment, None);
153 resolver,
154 trait_.into(),
155 resolved_segment,
156 None,
157 );
158 return if remaining_segments.len() == 1 { 152 return if remaining_segments.len() == 1 {
159 let segment = &remaining_segments[0]; 153 let segment = &remaining_segments[0];
160 let associated_ty = associated_type_by_name_including_super_traits( 154 let associated_ty = associated_type_by_name_including_super_traits(
@@ -187,7 +181,11 @@ impl Ty {
187 let name = resolved_segment.name.clone(); 181 let name = resolved_segment.name.clone();
188 Ty::Param { idx, name } 182 Ty::Param { idx, name }
189 } 183 }
190 TypeNs::SelfType(impl_block) => ImplBlock::from(impl_block).target_ty(db), 184 TypeNs::SelfType(impl_id) => {
185 let impl_data = db.impl_data(impl_id);
186 let resolver = impl_id.resolver(db);
187 Ty::from_hir(db, &resolver, &impl_data.target_type)
188 }
191 TypeNs::AdtSelfType(adt) => db.ty(adt.into()), 189 TypeNs::AdtSelfType(adt) => db.ty(adt.into()),
192 190
193 TypeNs::AdtId(it) => Ty::from_hir_path_inner(db, resolver, resolved_segment, it.into()), 191 TypeNs::AdtId(it) => Ty::from_hir_path_inner(db, resolver, resolved_segment, it.into()),
@@ -250,14 +248,11 @@ impl Ty {
250 GenericPredicate::Implemented(tr) if tr.self_ty() == &self_ty => Some(tr.trait_), 248 GenericPredicate::Implemented(tr) if tr.self_ty() == &self_ty => Some(tr.trait_),
251 _ => None, 249 _ => None,
252 }); 250 });
253 let traits = traits_from_env.flat_map(|t| all_super_traits(db, t)).map(Trait::from); 251 let traits = traits_from_env.flat_map(|t| all_super_traits(db, t));
254 for t in traits { 252 for t in traits {
255 if let Some(associated_ty) = db.trait_data(t.id).associated_type_by_name(&segment.name) 253 if let Some(associated_ty) = db.trait_data(t).associated_type_by_name(&segment.name) {
256 { 254 let substs =
257 let substs = Substs::build_for_def(db, t.id) 255 Substs::build_for_def(db, t).push(self_ty.clone()).fill_with_unknown().build();
258 .push(self_ty.clone())
259 .fill_with_unknown()
260 .build();
261 // FIXME handle type parameters on the segment 256 // FIXME handle type parameters on the segment
262 return Ty::Projection(ProjectionTy { associated_ty, parameters: substs }); 257 return Ty::Projection(ProjectionTy { associated_ty, parameters: substs });
263 } 258 }
@@ -391,7 +386,7 @@ impl TraitRef {
391 pub(super) fn from_resolved_path( 386 pub(super) fn from_resolved_path(
392 db: &impl HirDatabase, 387 db: &impl HirDatabase,
393 resolver: &Resolver, 388 resolver: &Resolver,
394 resolved: Trait, 389 resolved: TraitId,
395 segment: &PathSegment, 390 segment: &PathSegment,
396 explicit_self_ty: Option<Ty>, 391 explicit_self_ty: Option<Ty>,
397 ) -> Self { 392 ) -> Self {
@@ -399,7 +394,7 @@ impl TraitRef {
399 if let Some(self_ty) = explicit_self_ty { 394 if let Some(self_ty) = explicit_self_ty {
400 make_mut_slice(&mut substs.0)[0] = self_ty; 395 make_mut_slice(&mut substs.0)[0] = self_ty;
401 } 396 }
402 TraitRef { trait_: resolved.id, substs } 397 TraitRef { trait_: resolved, substs }
403 } 398 }
404 399
405 pub(crate) fn from_hir( 400 pub(crate) fn from_hir(
@@ -419,11 +414,11 @@ impl TraitRef {
419 db: &impl HirDatabase, 414 db: &impl HirDatabase,
420 resolver: &Resolver, 415 resolver: &Resolver,
421 segment: &PathSegment, 416 segment: &PathSegment,
422 resolved: Trait, 417 resolved: TraitId,
423 ) -> Substs { 418 ) -> Substs {
424 let has_self_param = 419 let has_self_param =
425 segment.args_and_bindings.as_ref().map(|a| a.has_self_type).unwrap_or(false); 420 segment.args_and_bindings.as_ref().map(|a| a.has_self_type).unwrap_or(false);
426 substs_from_path_segment(db, resolver, segment, Some(resolved.id.into()), !has_self_param) 421 substs_from_path_segment(db, resolver, segment, Some(resolved.into()), !has_self_param)
427 } 422 }
428 423
429 pub(crate) fn for_trait(db: &impl HirDatabase, trait_: TraitId) -> TraitRef { 424 pub(crate) fn for_trait(db: &impl HirDatabase, trait_: TraitId) -> TraitRef {