From bd8af6a413bb2f762bb696d20727e21cb2d4cb62 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Sat, 16 Nov 2019 00:05:10 +0300 Subject: Sourcify some more --- crates/ra_hir/src/source_binder.rs | 34 +++++++++++++++++++++------------- 1 file changed, 21 insertions(+), 13 deletions(-) (limited to 'crates/ra_hir/src') diff --git a/crates/ra_hir/src/source_binder.rs b/crates/ra_hir/src/source_binder.rs index f08827ed3..f3bccd8ed 100644 --- a/crates/ra_hir/src/source_binder.rs +++ b/crates/ra_hir/src/source_binder.rs @@ -141,13 +141,16 @@ impl SourceAnalyzer { node: &SyntaxNode, offset: Option, ) -> SourceAnalyzer { - let def_with_body = def_with_body_from_child_node(db, Source::new(file_id.into(), node)); + let node_source = Source::new(file_id.into(), node); + let def_with_body = def_with_body_from_child_node(db, node_source); if let Some(def) = def_with_body { let source_map = def.body_source_map(db); let scopes = def.expr_scopes(db); let scope = match offset { - None => scope_for(&scopes, &source_map, file_id.into(), &node), - Some(offset) => scope_for_offset(&scopes, &source_map, file_id.into(), offset), + None => scope_for(&scopes, &source_map, node_source), + Some(offset) => { + scope_for_offset(&scopes, &source_map, Source::new(file_id.into(), offset)) + } }; let resolver = expr::resolver_for_scope(db, def, scope); SourceAnalyzer { @@ -287,7 +290,8 @@ impl SourceAnalyzer { let name = name_ref.as_name(); let source_map = self.body_source_map.as_ref()?; let scopes = self.scopes.as_ref()?; - let scope = scope_for(scopes, source_map, self.file_id.into(), name_ref.syntax())?; + let scope = + scope_for(scopes, source_map, Source::new(self.file_id.into(), name_ref.syntax()))?; let entry = scopes.resolve_name_in_scope(scope, &name)?; Some(ScopeEntryWithSyntax { name: entry.name().clone(), @@ -408,20 +412,19 @@ impl SourceAnalyzer { fn scope_for( scopes: &ExprScopes, source_map: &BodySourceMap, - file_id: HirFileId, - node: &SyntaxNode, + node: Source<&SyntaxNode>, ) -> Option { - node.ancestors() + node.ast + .ancestors() .filter_map(ast::Expr::cast) - .filter_map(|it| source_map.node_expr(Source { file_id, ast: &it })) + .filter_map(|it| source_map.node_expr(Source::new(node.file_id, &it))) .find_map(|it| scopes.scope_for(it)) } fn scope_for_offset( scopes: &ExprScopes, source_map: &BodySourceMap, - file_id: HirFileId, - offset: TextUnit, + offset: Source, ) -> Option { scopes .scope_by_expr() @@ -429,7 +432,7 @@ fn scope_for_offset( .filter_map(|(id, scope)| { let source = source_map.expr_syntax(*id)?; // FIXME: correctly handle macro expansion - if source.file_id != file_id { + if source.file_id != offset.file_id { return None; } let syntax_node_ptr = @@ -438,9 +441,14 @@ fn scope_for_offset( }) // find containing scope .min_by_key(|(ptr, _scope)| { - (!(ptr.range().start() <= offset && offset <= ptr.range().end()), ptr.range().len()) + ( + !(ptr.range().start() <= offset.ast && offset.ast <= ptr.range().end()), + ptr.range().len(), + ) + }) + .map(|(ptr, scope)| { + adjust(scopes, source_map, ptr, offset.file_id, offset.ast).unwrap_or(*scope) }) - .map(|(ptr, scope)| adjust(scopes, source_map, ptr, file_id, offset).unwrap_or(*scope)) } // XXX: during completion, cursor might be outside of any particular -- cgit v1.2.3