@@ -22,6 +22,19 @@ use crate::{
22
22
input:: SourceRootId ,
23
23
} ;
24
24
25
+ /// Item map is the result of the name resolution. Item map contains, for each
26
+ /// module, the set of visible items.
27
+ #[ derive( Default , Debug , PartialEq , Eq ) ]
28
+ pub ( crate ) struct ItemMap {
29
+ per_module : FxHashMap < ModuleId , ModuleItems > ,
30
+ }
31
+
32
+ #[ derive( Debug , Default , PartialEq , Eq ) ]
33
+ struct ModuleItems {
34
+ items : FxHashMap < SmolStr , Resolution > ,
35
+ import_resolutions : FxHashMap < LocalSyntaxPtr , DefId > ,
36
+ }
37
+
25
38
/// A set of items and imports declared inside a module, without relation to
26
39
/// other modules.
27
40
///
@@ -101,19 +114,6 @@ pub(crate) fn item_map(
101
114
Ok ( Arc :: new ( res) )
102
115
}
103
116
104
- /// Item map is the result of the name resolution. Item map contains, for each
105
- /// module, the set of visible items.
106
- #[ derive( Default , Debug , PartialEq , Eq ) ]
107
- pub ( crate ) struct ItemMap {
108
- per_module : FxHashMap < ModuleId , ModuleItems > ,
109
- }
110
-
111
- #[ derive( Debug , Default , PartialEq , Eq ) ]
112
- struct ModuleItems {
113
- items : FxHashMap < SmolStr , Resolution > ,
114
- import_resolutions : FxHashMap < LocalSyntaxPtr , DefId > ,
115
- }
116
-
117
117
/// Resolution is basically `DefId` atm, but it should account for stuff like
118
118
/// multiple namespaces, ambiguity and errors.
119
119
#[ derive( Debug , Clone , PartialEq , Eq ) ]
0 commit comments