move crate to code_model_api
This commit is contained in:
parent
eaf553dade
commit
9a820dc0ee
26
crates/ra_hir/src/code_model_api.rs
Normal file
26
crates/ra_hir/src/code_model_api.rs
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
use ra_db::{CrateId, Cancelable};
|
||||||
|
|
||||||
|
use crate::{Module, Name, db::HirDatabase};
|
||||||
|
|
||||||
|
/// hir::Crate describes a single crate. It's the main inteface with which
|
||||||
|
/// crate's dependencies interact. Mostly, it should be just a proxy for the
|
||||||
|
/// root module.
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
|
||||||
|
pub struct Crate {
|
||||||
|
pub(crate) crate_id: CrateId,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct CrateDependency {
|
||||||
|
pub krate: Crate,
|
||||||
|
pub name: Name,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Crate {
|
||||||
|
pub fn dependencies(&self, db: &impl HirDatabase) -> Vec<CrateDependency> {
|
||||||
|
self.dependencies_impl(db)
|
||||||
|
}
|
||||||
|
pub fn root_module(&self, db: &impl HirDatabase) -> Cancelable<Option<Module>> {
|
||||||
|
self.root_module_impl(db)
|
||||||
|
}
|
||||||
|
}
|
@ -1,26 +1,12 @@
|
|||||||
pub use ra_db::{CrateId, Cancelable};
|
use ra_db::{CrateId, Cancelable};
|
||||||
|
|
||||||
use crate::{HirDatabase, Module, Name, AsName, HirFileId};
|
use crate::{Module, HirFileId, db::HirDatabase, Crate, CrateDependency, AsName};
|
||||||
|
|
||||||
/// hir::Crate describes a single crate. It's the main inteface with which
|
|
||||||
/// crate's dependencies interact. Mostly, it should be just a proxy for the
|
|
||||||
/// root module.
|
|
||||||
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
|
|
||||||
pub struct Crate {
|
|
||||||
crate_id: CrateId,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
|
||||||
pub struct CrateDependency {
|
|
||||||
pub krate: Crate,
|
|
||||||
pub name: Name,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Crate {
|
impl Crate {
|
||||||
pub(crate) fn new(crate_id: CrateId) -> Crate {
|
pub(crate) fn new(crate_id: CrateId) -> Crate {
|
||||||
Crate { crate_id }
|
Crate { crate_id }
|
||||||
}
|
}
|
||||||
pub fn dependencies(&self, db: &impl HirDatabase) -> Vec<CrateDependency> {
|
pub(crate) fn dependencies_impl(&self, db: &impl HirDatabase) -> Vec<CrateDependency> {
|
||||||
let crate_graph = db.crate_graph();
|
let crate_graph = db.crate_graph();
|
||||||
crate_graph
|
crate_graph
|
||||||
.dependencies(self.crate_id)
|
.dependencies(self.crate_id)
|
||||||
@ -31,7 +17,7 @@ impl Crate {
|
|||||||
})
|
})
|
||||||
.collect()
|
.collect()
|
||||||
}
|
}
|
||||||
pub fn root_module(&self, db: &impl HirDatabase) -> Cancelable<Option<Module>> {
|
pub(crate) fn root_module_impl(&self, db: &impl HirDatabase) -> Cancelable<Option<Module>> {
|
||||||
let crate_graph = db.crate_graph();
|
let crate_graph = db.crate_graph();
|
||||||
let file_id = crate_graph.crate_root(self.crate_id);
|
let file_id = crate_graph.crate_root(self.crate_id);
|
||||||
let source_root_id = db.file_source_root(file_id);
|
let source_root_id = db.file_source_root(file_id);
|
@ -24,8 +24,6 @@ pub mod source_binder;
|
|||||||
mod ids;
|
mod ids;
|
||||||
mod macros;
|
mod macros;
|
||||||
mod name;
|
mod name;
|
||||||
// can't use `crate` or `r#crate` here :(
|
|
||||||
mod krate;
|
|
||||||
mod module;
|
mod module;
|
||||||
mod function;
|
mod function;
|
||||||
mod adt;
|
mod adt;
|
||||||
@ -34,16 +32,19 @@ mod ty;
|
|||||||
mod impl_block;
|
mod impl_block;
|
||||||
mod expr;
|
mod expr;
|
||||||
|
|
||||||
|
pub mod code_model_api;
|
||||||
|
mod code_model_impl;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
db::HirDatabase,
|
db::HirDatabase,
|
||||||
name::{AsName, KnownName},
|
name::{AsName, KnownName},
|
||||||
ids::{DefKind, SourceItemId, SourceFileItemId, SourceFileItems},
|
ids::{DefKind, SourceItemId, SourceFileItemId, SourceFileItems},
|
||||||
|
code_model_api::{Crate, CrateDependency}
|
||||||
};
|
};
|
||||||
|
|
||||||
pub use self::{
|
pub use self::{
|
||||||
path::{Path, PathKind},
|
path::{Path, PathKind},
|
||||||
name::Name,
|
name::Name,
|
||||||
krate::Crate,
|
|
||||||
ids::{HirFileId, DefId, DefLoc, MacroCallId, MacroCallLoc},
|
ids::{HirFileId, DefId, DefLoc, MacroCallId, MacroCallLoc},
|
||||||
macros::{MacroDef, MacroInput, MacroExpansion},
|
macros::{MacroDef, MacroInput, MacroExpansion},
|
||||||
module::{Module, ModuleId, Problem, nameres::{ItemMap, PerNs, Namespace}, ModuleScope, Resolution},
|
module::{Module, ModuleId, Problem, nameres::{ItemMap, PerNs, Namespace}, ModuleScope, Resolution},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user