Unnamed repository; edit this file 'description' to name the repository.
use nodes from actual file
Max Heller 2023-07-30
parent 784379e · commit c4cff80
-rw-r--r--crates/ide-completion/src/context/analysis.rs25
1 files changed, 16 insertions, 9 deletions
diff --git a/crates/ide-completion/src/context/analysis.rs b/crates/ide-completion/src/context/analysis.rs
index 4f5266051b..aeec1ea6f7 100644
--- a/crates/ide-completion/src/context/analysis.rs
+++ b/crates/ide-completion/src/context/analysis.rs
@@ -883,18 +883,25 @@ fn classify_name_ref(
}
};
let make_path_kind_type = |ty: ast::Type| {
- let location = type_location(ty.syntax());
- if let Some(p) = ty.syntax().parent() {
- if ast::GenericArg::can_cast(p.kind()) || ast::GenericArgList::can_cast(p.kind()) {
- if let Some(p) = p.parent().and_then(|p| p.parent()) {
- if let Some(segment) = ast::PathSegment::cast(p) {
- let path = segment.parent_path().top_path();
- dbg!(sema.resolve_path(&path));
- }
+ let location = type_location(ty.syntax()).unwrap_or(TypeLocation::Other);
+ match &location {
+ TypeLocation::TupleField => (),
+ TypeLocation::TypeAscription(_) => (),
+ TypeLocation::GenericArgList(args) => {
+ dbg!(&args);
+ if let Some(segment) =
+ args.as_ref().and_then(|args| ast::PathSegment::cast(args.syntax().parent()?))
+ {
+ let path = dbg!(segment.parent_path().top_path());
+ dbg!(sema.resolve_path(&path));
}
}
+ TypeLocation::TypeBound => (),
+ TypeLocation::ImplTarget => (),
+ TypeLocation::ImplTrait => (),
+ TypeLocation::Other => (),
}
- PathKind::Type { location: location.unwrap_or(TypeLocation::Other) }
+ PathKind::Type { location }
};
let mut kind_macro_call = |it: ast::MacroCall| {