]> git.lizzy.rs Git - rust.git/commitdiff
Move Source to hir_expand
authorAleksey Kladov <aleksey.kladov@gmail.com>
Sat, 2 Nov 2019 20:11:05 +0000 (23:11 +0300)
committerAleksey Kladov <aleksey.kladov@gmail.com>
Sat, 2 Nov 2019 20:11:27 +0000 (23:11 +0300)
crates/ra_hir/src/code_model/src.rs
crates/ra_hir/src/lib.rs
crates/ra_hir_def/src/lib.rs
crates/ra_hir_expand/src/lib.rs

index 0f4c78df760d8655e88a1055f96d56ac53aa5390..bd0c3c226aa474ebe284668c2251343bc832ee8e 100644 (file)
@@ -10,7 +10,7 @@
     ModuleSource, Static, Struct, StructField, Trait, TypeAlias, Union,
 };
 
-pub use hir_def::Source;
+pub use hir_expand::Source;
 
 pub trait HasSource {
     type Ast;
index 40f5562b406a82dd111dbd0790519d71bb9bb4f2..0ba17e5710d307e31d43d068fa4fe5313d2a3fe1 100644 (file)
@@ -62,7 +62,7 @@ fn from(it: $sv) -> $e {
     adt::VariantDef,
     code_model::{
         docs::{DocDef, Docs, Documentation},
-        src::{HasBodySource, HasSource, Source},
+        src::{HasBodySource, HasSource},
         Adt, AssocItem, Const, ConstData, Container, Crate, CrateDependency, DefWithBody, Enum,
         EnumVariant, FieldSource, FnData, Function, HasBody, MacroDef, Module, ModuleDef,
         ModuleSource, Static, Struct, StructField, Trait, TypeAlias, Union,
@@ -85,4 +85,4 @@ fn from(it: $sv) -> $e {
     path::{Path, PathKind},
     type_ref::Mutability,
 };
-pub use hir_expand::{either::Either, name::Name};
+pub use hir_expand::{either::Either, name::Name, Source};
index 76d5f18522bc685ccb09c65cb151cce293aac959..6d66f481d3f81de2bccebdda7612ca5cec044ed2 100644 (file)
 
 use std::hash::{Hash, Hasher};
 
-use hir_expand::{ast_id_map::FileAstId, db::AstDatabase, AstId, HirFileId};
+use hir_expand::{ast_id_map::FileAstId, db::AstDatabase, AstId, HirFileId, Source};
 use ra_arena::{impl_arena_id, RawId};
 use ra_db::{salsa, CrateId, FileId};
 use ra_syntax::{ast, AstNode, SyntaxNode};
 
 use crate::{builtin_type::BuiltinType, db::InternDatabase};
 
-#[derive(Debug, PartialEq, Eq, Clone, Copy)]
-pub struct Source<T> {
-    pub file_id: HirFileId,
-    pub ast: T,
-}
-
 pub enum ModuleSource {
     SourceFile(ast::SourceFile),
     Module(ast::Module),
@@ -94,15 +88,6 @@ pub fn from_file_id(db: &impl db::DefDatabase2, file_id: FileId) -> ModuleSource
     }
 }
 
-impl<T> Source<T> {
-    pub fn map<F: FnOnce(T) -> U, U>(self, f: F) -> Source<U> {
-        Source { file_id: self.file_id, ast: f(self.ast) }
-    }
-    pub fn file_syntax(&self, db: &impl AstDatabase) -> SyntaxNode {
-        db.parse_or_expand(self.file_id).expect("source created from invalid file")
-    }
-}
-
 #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
 pub struct ModuleId {
     pub krate: CrateId,
index 5a0e5a19c5335c31f990bcd4bd882dc59a39af00..85c2b22ace5a50bf566c44f5c8437072140973af 100644 (file)
 use std::hash::{Hash, Hasher};
 
 use ra_db::{salsa, CrateId, FileId};
-use ra_syntax::ast::{self, AstNode};
+use ra_syntax::{
+    ast::{self, AstNode},
+    SyntaxNode,
+};
 
 use crate::ast_id_map::FileAstId;
 
@@ -151,3 +154,18 @@ pub fn to_node(&self, db: &dyn db::AstDatabase) -> N {
         db.ast_id_map(self.file_id).get(self.file_ast_id).to_node(&root)
     }
 }
+
+#[derive(Debug, PartialEq, Eq, Clone, Copy)]
+pub struct Source<T> {
+    pub file_id: HirFileId,
+    pub ast: T,
+}
+
+impl<T> Source<T> {
+    pub fn map<F: FnOnce(T) -> U, U>(self, f: F) -> Source<U> {
+        Source { file_id: self.file_id, ast: f(self.ast) }
+    }
+    pub fn file_syntax(&self, db: &impl db::AstDatabase) -> SyntaxNode {
+        db.parse_or_expand(self.file_id).expect("source created from invalid file")
+    }
+}