aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_hir_def/src/nameres/collector.rs
diff options
context:
space:
mode:
Diffstat (limited to 'crates/ra_hir_def/src/nameres/collector.rs')
-rw-r--r--crates/ra_hir_def/src/nameres/collector.rs28
1 files changed, 25 insertions, 3 deletions
diff --git a/crates/ra_hir_def/src/nameres/collector.rs b/crates/ra_hir_def/src/nameres/collector.rs
index aacd50df8..5f18e9de3 100644
--- a/crates/ra_hir_def/src/nameres/collector.rs
+++ b/crates/ra_hir_def/src/nameres/collector.rs
@@ -1,8 +1,9 @@
1//! FIXME: write short doc here 1//! FIXME: write short doc here
2 2
3use hir_expand::{ 3use hir_expand::{
4 builtin_macro::find_builtin_macro,
4 name::{self, AsName, Name}, 5 name::{self, AsName, Name},
5 HirFileId, MacroCallId, MacroCallLoc, MacroDefId, MacroFileKind, 6 DeclarativeMacro, HirFileId, MacroCallId, MacroCallLoc, MacroDefId, MacroFileKind,
6}; 7};
7use ra_cfg::CfgOptions; 8use ra_cfg::CfgOptions;
8use ra_db::{CrateId, FileId}; 9use ra_db::{CrateId, FileId};
@@ -688,11 +689,32 @@ where
688 fn collect_macro(&mut self, mac: &raw::MacroData) { 689 fn collect_macro(&mut self, mac: &raw::MacroData) {
689 let ast_id = AstId::new(self.file_id, mac.ast_id); 690 let ast_id = AstId::new(self.file_id, mac.ast_id);
690 691
692 // Case 0: builtin macros
693 if mac.builtin {
694 if let Some(name) = &mac.name {
695 let krate = self.def_collector.def_map.krate;
696 if let Some(macro_id) = find_builtin_macro(name, krate, ast_id) {
697 self.def_collector.define_macro(
698 self.module_id,
699 name.clone(),
700 macro_id,
701 mac.export,
702 );
703 return;
704 }
705 }
706 }
707
691 // Case 1: macro rules, define a macro in crate-global mutable scope 708 // Case 1: macro rules, define a macro in crate-global mutable scope
692 if is_macro_rules(&mac.path) { 709 if is_macro_rules(&mac.path) {
693 if let Some(name) = &mac.name { 710 if let Some(name) = &mac.name {
694 let macro_id = MacroDefId { ast_id, krate: self.def_collector.def_map.krate }; 711 let macro_id = DeclarativeMacro { ast_id, krate: self.def_collector.def_map.krate };
695 self.def_collector.define_macro(self.module_id, name.clone(), macro_id, mac.export); 712 self.def_collector.define_macro(
713 self.module_id,
714 name.clone(),
715 MacroDefId::DeclarativeMacro(macro_id),
716 mac.export,
717 );
696 } 718 }
697 return; 719 return;
698 } 720 }