From 6d3b0af900e6cefb507939b311672b7795703461 Mon Sep 17 00:00:00 2001 From: Edwin Cheng Date: Tue, 28 Apr 2020 03:32:47 +0800 Subject: [PATCH] Use empty-deps tricks to detect it is core --- crates/ra_hir_expand/src/builtin_derive.rs | 26 +++++++++++++++++----- crates/ra_hir_ty/src/tests/macros.rs | 11 +++++---- 2 files changed, 26 insertions(+), 11 deletions(-) diff --git a/crates/ra_hir_expand/src/builtin_derive.rs b/crates/ra_hir_expand/src/builtin_derive.rs index cc8c453472..3bd3f7041e 100644 --- a/crates/ra_hir_expand/src/builtin_derive.rs +++ b/crates/ra_hir_expand/src/builtin_derive.rs @@ -160,11 +160,17 @@ fn find_builtin_crate(db: &dyn AstDatabase, id: LazyMacroId) -> tt::TokenTree { let m: MacroCallId = id.into(); let file_id = m.as_file().original_file(db); let cg = db.crate_graph(); - let crates = db.relevant_crates(file_id); - let mut crate_names = - crates.iter().filter_map(|krate| cg[*krate].display_name.clone()).map(|it| it.to_string()); + let krates = db.relevant_crates(file_id); + let krate = match krates.get(0) { + Some(krate) => krate, + None => { + let tt = quote! { core }; + return tt.token_trees[0].clone(); + } + }; - let tt = if crate_names.any(|name| name == "std" || name == "core") { + // Check whether it has any deps, if not, it should be core: + let tt = if cg[*krate].dependencies.is_empty() { quote! { crate } } else { quote! { core } @@ -263,8 +269,18 @@ mod tests { fn expand_builtin_derive(s: &str, name: Name) -> String { let def = find_builtin_derive(&name).unwrap(); + let fixture = format!( + r#"//- /main.rs crate:main deps:core +<|> +{} +//- /lib.rs crate:core +// empty +"#, + s + ); - let (db, file_id) = TestDB::with_single_file(&s); + let (db, file_pos) = TestDB::with_position(&fixture); + let file_id = file_pos.file_id; let parsed = db.parse(file_id); let items: Vec<_> = parsed.syntax_node().descendants().filter_map(ast::ModuleItem::cast).collect(); diff --git a/crates/ra_hir_ty/src/tests/macros.rs b/crates/ra_hir_ty/src/tests/macros.rs index ac5485bc97..5ddecbdc68 100644 --- a/crates/ra_hir_ty/src/tests/macros.rs +++ b/crates/ra_hir_ty/src/tests/macros.rs @@ -646,12 +646,6 @@ mod clone { fn infer_derive_clone_in_core() { let (db, pos) = TestDB::with_position( r#" -//- /main.rs crate:main deps:core -use core::S; -fn test() { - S.clone()<|>; -} - //- /lib.rs crate:core #[prelude_import] use clone::*; @@ -663,6 +657,11 @@ mod clone { #[derive(Clone)] pub struct S; +//- /main.rs crate:main deps:core +use core::S; +fn test() { + S.clone()<|>; +} "#, ); assert_eq!("S", type_at_pos(&db, pos));