mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 05:38:46 +00:00
renames
This commit is contained in:
parent
8c737255ff
commit
47be3a3a24
3 changed files with 49 additions and 47 deletions
|
@ -120,38 +120,36 @@ impl<'a> QueryCtx<'a> {
|
|||
|
||||
fn query_config() -> salsa::QueryConfig<State, Data> {
|
||||
let mut res = salsa::QueryConfig::new();
|
||||
let queries: Vec<SalsaGroundQuery> = vec![
|
||||
let queries: Vec<BoxedGroundQuery> = vec![
|
||||
queries::FILE_TEXT.into(),
|
||||
queries::FILE_SET.into(),
|
||||
];
|
||||
for q in queries {
|
||||
res = res.with_ground_query(q.query_type, q.f)
|
||||
}
|
||||
let queries: Vec<SalsaQuery> = vec![
|
||||
let mut queries: Vec<BoxedQuery> = vec![
|
||||
queries::FILE_SYNTAX.into(),
|
||||
::module_map_db::MODULE_DESCR.into(),
|
||||
::module_map_db::RESOLVE_SUBMODULE.into(),
|
||||
::module_map_db::PARENT_MODULE.into(),
|
||||
];
|
||||
::module_map_db::queries(&mut queries);
|
||||
for q in queries {
|
||||
res = res.with_query(q.query_type, q.f);
|
||||
}
|
||||
res
|
||||
}
|
||||
|
||||
struct SalsaGroundQuery {
|
||||
struct BoxedGroundQuery {
|
||||
query_type: salsa::QueryTypeId,
|
||||
f: Box<Fn(&State, &Data) -> (Data, salsa::OutputFingerprint) + Send + Sync + 'static>,
|
||||
}
|
||||
|
||||
impl<T, R> From<GroundQuery<T, R>> for SalsaGroundQuery
|
||||
impl<T, R> From<GroundQuery<T, R>> for BoxedGroundQuery
|
||||
where
|
||||
T: Send + Sync + 'static,
|
||||
R: Send + Sync + 'static,
|
||||
{
|
||||
fn from(q: GroundQuery<T, R>) -> SalsaGroundQuery
|
||||
fn from(q: GroundQuery<T, R>) -> BoxedGroundQuery
|
||||
{
|
||||
SalsaGroundQuery {
|
||||
BoxedGroundQuery {
|
||||
query_type: salsa::QueryTypeId(q.id),
|
||||
f: Box::new(move |state, data| {
|
||||
let data: &T = data.downcast_ref().unwrap();
|
||||
|
@ -163,19 +161,19 @@ where
|
|||
}
|
||||
}
|
||||
|
||||
struct SalsaQuery {
|
||||
pub(crate) struct BoxedQuery {
|
||||
query_type: salsa::QueryTypeId,
|
||||
f: Box<Fn(&salsa::QueryCtx<State, Data>, &Data) -> (Data, salsa::OutputFingerprint) + Send + Sync + 'static>,
|
||||
}
|
||||
|
||||
impl<T, R> From<Query<T, R>> for SalsaQuery
|
||||
impl<T, R> From<Query<T, R>> for BoxedQuery
|
||||
where
|
||||
T: Hash + Send + Sync + 'static,
|
||||
R: Hash + Send + Sync + 'static,
|
||||
{
|
||||
fn from(q: Query<T, R>) -> SalsaQuery
|
||||
fn from(q: Query<T, R>) -> BoxedQuery
|
||||
{
|
||||
SalsaQuery {
|
||||
BoxedQuery {
|
||||
query_type: salsa::QueryTypeId(q.id),
|
||||
f: Box::new(move |ctx, data| {
|
||||
let ctx = QueryCtx { inner: ctx };
|
||||
|
|
29
crates/libanalysis/src/module_map_db/descr.rs
Normal file
29
crates/libanalysis/src/module_map_db/descr.rs
Normal file
|
@ -0,0 +1,29 @@
|
|||
use libsyntax2::{
|
||||
SmolStr,
|
||||
ast::{self, NameOwner},
|
||||
};
|
||||
|
||||
#[derive(Debug, Hash)]
|
||||
pub struct ModuleDescr {
|
||||
pub submodules: Vec<Submodule>
|
||||
}
|
||||
|
||||
impl ModuleDescr {
|
||||
pub fn new(root: ast::Root) -> ModuleDescr {
|
||||
let submodules = root
|
||||
.modules()
|
||||
.filter_map(|module| {
|
||||
let name = module.name()?.text();
|
||||
if !module.has_semi() {
|
||||
return None;
|
||||
}
|
||||
Some(Submodule { name })
|
||||
}).collect();
|
||||
|
||||
ModuleDescr { submodules } }
|
||||
}
|
||||
|
||||
#[derive(Clone, Hash, PartialEq, Eq, Debug)]
|
||||
pub struct Submodule {
|
||||
pub name: SmolStr,
|
||||
}
|
|
@ -1,12 +1,20 @@
|
|||
mod descr;
|
||||
|
||||
use std::sync::Arc;
|
||||
use {
|
||||
FileId,
|
||||
db::{
|
||||
Query, QueryCtx
|
||||
BoxedQuery, Query, QueryCtx
|
||||
},
|
||||
module_map::resolve_submodule,
|
||||
};
|
||||
|
||||
pub(crate) fn queries(acc: &mut Vec<BoxedQuery>) {
|
||||
acc.push(MODULE_DESCR.into());
|
||||
acc.push(RESOLVE_SUBMODULE.into());
|
||||
acc.push(PARENT_MODULE.into());
|
||||
}
|
||||
|
||||
impl<'a> QueryCtx<'a> {
|
||||
fn module_descr(&self, file_id: FileId) -> Arc<descr::ModuleDescr> {
|
||||
self.get(MODULE_DESCR, file_id)
|
||||
|
@ -52,39 +60,6 @@ pub(crate) const PARENT_MODULE: Query<FileId, Vec<FileId>> = Query {
|
|||
}
|
||||
};
|
||||
|
||||
mod descr {
|
||||
use libsyntax2::{
|
||||
SmolStr,
|
||||
ast::{self, NameOwner},
|
||||
};
|
||||
|
||||
#[derive(Debug, Hash)]
|
||||
pub struct ModuleDescr {
|
||||
pub submodules: Vec<Submodule>
|
||||
}
|
||||
|
||||
impl ModuleDescr {
|
||||
pub fn new(root: ast::Root) -> ModuleDescr {
|
||||
let submodules = root
|
||||
.modules()
|
||||
.filter_map(|module| {
|
||||
let name = module.name()?.text();
|
||||
if !module.has_semi() {
|
||||
return None;
|
||||
}
|
||||
Some(Submodule { name })
|
||||
}).collect();
|
||||
|
||||
ModuleDescr { submodules } }
|
||||
}
|
||||
|
||||
#[derive(Clone, Hash, PartialEq, Eq, Debug)]
|
||||
pub struct Submodule {
|
||||
pub name: SmolStr,
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use std::collections::HashMap;
|
Loading…
Reference in a new issue