mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-28 04:45:05 +00:00
Auto merge of #16143 - Veykril:base-db-no-proc-macros, r=lnicola
internal: Move proc-macro knowledge out of base-db into hir-expand It does not make much sense to me to have that live in base-db, additionally, it kind of conflicts with moving span things out into a separate crate
This commit is contained in:
commit
cfc959d73a
50 changed files with 255 additions and 186 deletions
2
Cargo.lock
generated
2
Cargo.lock
generated
|
@ -544,6 +544,7 @@ dependencies = [
|
||||||
"smallvec",
|
"smallvec",
|
||||||
"stdx",
|
"stdx",
|
||||||
"syntax",
|
"syntax",
|
||||||
|
"test-utils",
|
||||||
"tracing",
|
"tracing",
|
||||||
"triomphe",
|
"triomphe",
|
||||||
"tt",
|
"tt",
|
||||||
|
@ -903,6 +904,7 @@ version = "0.0.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"crossbeam-channel",
|
"crossbeam-channel",
|
||||||
|
"hir-expand",
|
||||||
"ide",
|
"ide",
|
||||||
"ide-db",
|
"ide-db",
|
||||||
"itertools",
|
"itertools",
|
||||||
|
|
|
@ -7,18 +7,17 @@ use salsa::Durability;
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
use vfs::FileId;
|
use vfs::FileId;
|
||||||
|
|
||||||
use crate::{CrateGraph, ProcMacros, SourceDatabaseExt, SourceRoot, SourceRootId};
|
use crate::{CrateGraph, SourceDatabaseExt, SourceRoot, SourceRootId};
|
||||||
|
|
||||||
/// Encapsulate a bunch of raw `.set` calls on the database.
|
/// Encapsulate a bunch of raw `.set` calls on the database.
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
pub struct Change {
|
pub struct FileChange {
|
||||||
pub roots: Option<Vec<SourceRoot>>,
|
pub roots: Option<Vec<SourceRoot>>,
|
||||||
pub files_changed: Vec<(FileId, Option<Arc<str>>)>,
|
pub files_changed: Vec<(FileId, Option<Arc<str>>)>,
|
||||||
pub crate_graph: Option<CrateGraph>,
|
pub crate_graph: Option<CrateGraph>,
|
||||||
pub proc_macros: Option<ProcMacros>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl fmt::Debug for Change {
|
impl fmt::Debug for FileChange {
|
||||||
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
let mut d = fmt.debug_struct("Change");
|
let mut d = fmt.debug_struct("Change");
|
||||||
if let Some(roots) = &self.roots {
|
if let Some(roots) = &self.roots {
|
||||||
|
@ -34,9 +33,9 @@ impl fmt::Debug for Change {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Change {
|
impl FileChange {
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
Change::default()
|
FileChange::default()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_roots(&mut self, roots: Vec<SourceRoot>) {
|
pub fn set_roots(&mut self, roots: Vec<SourceRoot>) {
|
||||||
|
@ -51,10 +50,6 @@ impl Change {
|
||||||
self.crate_graph = Some(graph);
|
self.crate_graph = Some(graph);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_proc_macros(&mut self, proc_macros: ProcMacros) {
|
|
||||||
self.proc_macros = Some(proc_macros);
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn apply(self, db: &mut dyn SourceDatabaseExt) {
|
pub fn apply(self, db: &mut dyn SourceDatabaseExt) {
|
||||||
let _p = profile::span("RootDatabase::apply_change");
|
let _p = profile::span("RootDatabase::apply_change");
|
||||||
if let Some(roots) = self.roots {
|
if let Some(roots) = self.roots {
|
||||||
|
@ -79,9 +74,6 @@ impl Change {
|
||||||
if let Some(crate_graph) = self.crate_graph {
|
if let Some(crate_graph) = self.crate_graph {
|
||||||
db.set_crate_graph_with_durability(Arc::new(crate_graph), Durability::HIGH);
|
db.set_crate_graph_with_durability(Arc::new(crate_graph), Durability::HIGH);
|
||||||
}
|
}
|
||||||
if let Some(proc_macros) = self.proc_macros {
|
|
||||||
db.set_proc_macros_with_durability(Arc::new(proc_macros), Durability::HIGH);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
//! actual IO. See `vfs` and `project_model` in the `rust-analyzer` crate for how
|
//! actual IO. See `vfs` and `project_model` in the `rust-analyzer` crate for how
|
||||||
//! actual IO is done and lowered to input.
|
//! actual IO is done and lowered to input.
|
||||||
|
|
||||||
use std::{fmt, mem, ops, panic::RefUnwindSafe, str::FromStr, sync};
|
use std::{fmt, mem, ops, str::FromStr};
|
||||||
|
|
||||||
use cfg::CfgOptions;
|
use cfg::CfgOptions;
|
||||||
use la_arena::{Arena, Idx};
|
use la_arena::{Arena, Idx};
|
||||||
|
@ -15,13 +15,9 @@ use syntax::SmolStr;
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
use vfs::{file_set::FileSet, AbsPathBuf, AnchoredPath, FileId, VfsPath};
|
use vfs::{file_set::FileSet, AbsPathBuf, AnchoredPath, FileId, VfsPath};
|
||||||
|
|
||||||
use crate::span::SpanData;
|
|
||||||
|
|
||||||
// Map from crate id to the name of the crate and path of the proc-macro. If the value is `None`,
|
// Map from crate id to the name of the crate and path of the proc-macro. If the value is `None`,
|
||||||
// then the crate for the proc-macro hasn't been build yet as the build data is missing.
|
// then the crate for the proc-macro hasn't been build yet as the build data is missing.
|
||||||
pub type ProcMacroPaths = FxHashMap<CrateId, Result<(Option<String>, AbsPathBuf), String>>;
|
pub type ProcMacroPaths = FxHashMap<CrateId, Result<(Option<String>, AbsPathBuf), String>>;
|
||||||
pub type ProcMacros = FxHashMap<CrateId, ProcMacroLoadResult>;
|
|
||||||
|
|
||||||
/// Files are grouped into source roots. A source root is a directory on the
|
/// Files are grouped into source roots. A source root is a directory on the
|
||||||
/// file systems which is watched for changes. Typically it corresponds to a
|
/// file systems which is watched for changes. Typically it corresponds to a
|
||||||
/// Rust crate. Source roots *might* be nested: in this case, a file belongs to
|
/// Rust crate. Source roots *might* be nested: in this case, a file belongs to
|
||||||
|
@ -242,49 +238,8 @@ impl CrateDisplayName {
|
||||||
CrateDisplayName { crate_name, canonical_name }
|
CrateDisplayName { crate_name, canonical_name }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: These should not be defined in here? Why does base db know about proc-macros
|
|
||||||
// ProcMacroKind is used in [`fixture`], but that module probably shouldn't be in this crate either.
|
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
|
|
||||||
pub struct ProcMacroId(pub u32);
|
|
||||||
|
|
||||||
#[derive(Copy, Clone, Eq, PartialEq, Debug, Hash)]
|
|
||||||
pub enum ProcMacroKind {
|
|
||||||
CustomDerive,
|
|
||||||
FuncLike,
|
|
||||||
Attr,
|
|
||||||
}
|
|
||||||
|
|
||||||
pub trait ProcMacroExpander: fmt::Debug + Send + Sync + RefUnwindSafe {
|
|
||||||
fn expand(
|
|
||||||
&self,
|
|
||||||
subtree: &tt::Subtree<SpanData>,
|
|
||||||
attrs: Option<&tt::Subtree<SpanData>>,
|
|
||||||
env: &Env,
|
|
||||||
def_site: SpanData,
|
|
||||||
call_site: SpanData,
|
|
||||||
mixed_site: SpanData,
|
|
||||||
) -> Result<tt::Subtree<SpanData>, ProcMacroExpansionError>;
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
|
||||||
pub enum ProcMacroExpansionError {
|
|
||||||
Panic(String),
|
|
||||||
/// Things like "proc macro server was killed by OOM".
|
|
||||||
System(String),
|
|
||||||
}
|
|
||||||
|
|
||||||
pub type ProcMacroLoadResult = Result<Vec<ProcMacro>, String>;
|
|
||||||
pub type TargetLayoutLoadResult = Result<Arc<str>, Arc<str>>;
|
pub type TargetLayoutLoadResult = Result<Arc<str>, Arc<str>>;
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
|
||||||
pub struct ProcMacro {
|
|
||||||
pub name: SmolStr,
|
|
||||||
pub kind: ProcMacroKind,
|
|
||||||
pub expander: sync::Arc<dyn ProcMacroExpander>,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash, PartialOrd, Ord)]
|
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash, PartialOrd, Ord)]
|
||||||
pub enum ReleaseChannel {
|
pub enum ReleaseChannel {
|
||||||
Stable,
|
Stable,
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
|
|
||||||
mod input;
|
mod input;
|
||||||
mod change;
|
mod change;
|
||||||
pub mod fixture;
|
|
||||||
pub mod span;
|
pub mod span;
|
||||||
|
|
||||||
use std::panic;
|
use std::panic;
|
||||||
|
@ -14,12 +13,11 @@ use syntax::{ast, Parse, SourceFile, TextRange, TextSize};
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
||||||
pub use crate::{
|
pub use crate::{
|
||||||
change::Change,
|
change::FileChange,
|
||||||
input::{
|
input::{
|
||||||
CrateData, CrateDisplayName, CrateGraph, CrateId, CrateName, CrateOrigin, Dependency,
|
CrateData, CrateDisplayName, CrateGraph, CrateId, CrateName, CrateOrigin, Dependency,
|
||||||
DependencyKind, Edition, Env, LangCrateOrigin, ProcMacro, ProcMacroExpander,
|
DependencyKind, Edition, Env, LangCrateOrigin, ProcMacroPaths, ReleaseChannel, SourceRoot,
|
||||||
ProcMacroExpansionError, ProcMacroId, ProcMacroKind, ProcMacroLoadResult, ProcMacroPaths,
|
SourceRootId, TargetLayoutLoadResult,
|
||||||
ProcMacros, ReleaseChannel, SourceRoot, SourceRootId, TargetLayoutLoadResult,
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
pub use salsa::{self, Cancelled};
|
pub use salsa::{self, Cancelled};
|
||||||
|
@ -74,10 +72,6 @@ pub trait SourceDatabase: FileLoader + std::fmt::Debug {
|
||||||
/// The crate graph.
|
/// The crate graph.
|
||||||
#[salsa::input]
|
#[salsa::input]
|
||||||
fn crate_graph(&self) -> Arc<CrateGraph>;
|
fn crate_graph(&self) -> Arc<CrateGraph>;
|
||||||
|
|
||||||
/// The proc macros.
|
|
||||||
#[salsa::input]
|
|
||||||
fn proc_macros(&self) -> Arc<ProcMacros>;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse(db: &dyn SourceDatabase, file_id: FileId) -> Parse<ast::SourceFile> {
|
fn parse(db: &dyn SourceDatabase, file_id: FileId) -> Parse<ast::SourceFile> {
|
||||||
|
|
|
@ -267,8 +267,8 @@ fn compute_expr_scopes(expr: ExprId, body: &Body, scopes: &mut ExprScopes, scope
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use base_db::{fixture::WithFixture, FileId, SourceDatabase};
|
use base_db::{FileId, SourceDatabase};
|
||||||
use hir_expand::{name::AsName, InFile};
|
use hir_expand::{fixture::WithFixture, name::AsName, InFile};
|
||||||
use syntax::{algo::find_node_at_offset, ast, AstNode};
|
use syntax::{algo::find_node_at_offset, ast, AstNode};
|
||||||
use test_utils::{assert_eq_text, extract_offset};
|
use test_utils::{assert_eq_text, extract_offset};
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
mod block;
|
mod block;
|
||||||
|
|
||||||
use base_db::{fixture::WithFixture, SourceDatabase};
|
use base_db::SourceDatabase;
|
||||||
use expect_test::{expect, Expect};
|
use expect_test::{expect, Expect};
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
|
|
||||||
use crate::{test_db::TestDB, ModuleDefId};
|
use crate::{test_db::TestDB, ModuleDefId};
|
||||||
|
|
||||||
|
|
|
@ -585,8 +585,7 @@ fn find_local_import_locations(
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use base_db::fixture::WithFixture;
|
use hir_expand::{db::ExpandDatabase, fixture::WithFixture};
|
||||||
use hir_expand::db::ExpandDatabase;
|
|
||||||
use syntax::ast::AstNode;
|
use syntax::ast::AstNode;
|
||||||
|
|
||||||
use crate::test_db::TestDB;
|
use crate::test_db::TestDB;
|
||||||
|
|
|
@ -473,8 +473,9 @@ pub fn search_dependencies(
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use base_db::{fixture::WithFixture, SourceDatabase, Upcast};
|
use base_db::{SourceDatabase, Upcast};
|
||||||
use expect_test::{expect, Expect};
|
use expect_test::{expect, Expect};
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
|
|
||||||
use crate::{db::DefDatabase, test_db::TestDB, ItemContainerId, Lookup};
|
use crate::{db::DefDatabase, test_db::TestDB, ItemContainerId, Lookup};
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use base_db::fixture::WithFixture;
|
|
||||||
use expect_test::{expect, Expect};
|
use expect_test::{expect, Expect};
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
|
|
||||||
use crate::{db::DefDatabase, test_db::TestDB};
|
use crate::{db::DefDatabase, test_db::TestDB};
|
||||||
|
|
||||||
|
|
|
@ -63,7 +63,7 @@ use std::{
|
||||||
panic::{RefUnwindSafe, UnwindSafe},
|
panic::{RefUnwindSafe, UnwindSafe},
|
||||||
};
|
};
|
||||||
|
|
||||||
use base_db::{impl_intern_key, salsa, span::SyntaxContextId, CrateId, ProcMacroKind};
|
use base_db::{impl_intern_key, salsa, span::SyntaxContextId, CrateId};
|
||||||
use hir_expand::{
|
use hir_expand::{
|
||||||
ast_id_map::{AstIdNode, FileAstId},
|
ast_id_map::{AstIdNode, FileAstId},
|
||||||
attrs::{Attr, AttrId, AttrInput},
|
attrs::{Attr, AttrId, AttrInput},
|
||||||
|
@ -73,7 +73,7 @@ use hir_expand::{
|
||||||
db::ExpandDatabase,
|
db::ExpandDatabase,
|
||||||
eager::expand_eager_macro_input,
|
eager::expand_eager_macro_input,
|
||||||
name::Name,
|
name::Name,
|
||||||
proc_macro::ProcMacroExpander,
|
proc_macro::{CustomProcMacroExpander, ProcMacroKind},
|
||||||
AstId, ExpandError, ExpandResult, ExpandTo, HirFileId, InFile, MacroCallId, MacroCallKind,
|
AstId, ExpandError, ExpandResult, ExpandTo, HirFileId, InFile, MacroCallId, MacroCallKind,
|
||||||
MacroDefId, MacroDefKind,
|
MacroDefId, MacroDefKind,
|
||||||
};
|
};
|
||||||
|
@ -400,7 +400,7 @@ pub struct ProcMacroId(salsa::InternId);
|
||||||
pub struct ProcMacroLoc {
|
pub struct ProcMacroLoc {
|
||||||
pub container: CrateRootModuleId,
|
pub container: CrateRootModuleId,
|
||||||
pub id: ItemTreeId<Function>,
|
pub id: ItemTreeId<Function>,
|
||||||
pub expander: ProcMacroExpander,
|
pub expander: CustomProcMacroExpander,
|
||||||
pub kind: ProcMacroKind,
|
pub kind: ProcMacroKind,
|
||||||
}
|
}
|
||||||
impl_intern!(ProcMacroId, ProcMacroLoc, intern_proc_macro, lookup_intern_proc_macro);
|
impl_intern!(ProcMacroId, ProcMacroLoc, intern_proc_macro, lookup_intern_proc_macro);
|
||||||
|
|
|
@ -16,9 +16,15 @@ mod proc_macros;
|
||||||
|
|
||||||
use std::{iter, ops::Range, sync};
|
use std::{iter, ops::Range, sync};
|
||||||
|
|
||||||
use base_db::{fixture::WithFixture, span::SpanData, ProcMacro, SourceDatabase};
|
use base_db::{span::SpanData, SourceDatabase};
|
||||||
use expect_test::Expect;
|
use expect_test::Expect;
|
||||||
use hir_expand::{db::ExpandDatabase, span::SpanMapRef, InFile, MacroFileId, MacroFileIdExt};
|
use hir_expand::{
|
||||||
|
db::ExpandDatabase,
|
||||||
|
fixture::WithFixture,
|
||||||
|
proc_macro::{ProcMacro, ProcMacroExpander, ProcMacroExpansionError, ProcMacroKind},
|
||||||
|
span::SpanMapRef,
|
||||||
|
InFile, MacroFileId, MacroFileIdExt,
|
||||||
|
};
|
||||||
use stdx::format_to;
|
use stdx::format_to;
|
||||||
use syntax::{
|
use syntax::{
|
||||||
ast::{self, edit::IndentLevel},
|
ast::{self, edit::IndentLevel},
|
||||||
|
@ -50,7 +56,7 @@ pub fn identity_when_valid(_attr: TokenStream, item: TokenStream) -> TokenStream
|
||||||
.into(),
|
.into(),
|
||||||
ProcMacro {
|
ProcMacro {
|
||||||
name: "identity_when_valid".into(),
|
name: "identity_when_valid".into(),
|
||||||
kind: base_db::ProcMacroKind::Attr,
|
kind: ProcMacroKind::Attr,
|
||||||
expander: sync::Arc::new(IdentityWhenValidProcMacroExpander),
|
expander: sync::Arc::new(IdentityWhenValidProcMacroExpander),
|
||||||
},
|
},
|
||||||
)];
|
)];
|
||||||
|
@ -307,7 +313,7 @@ fn pretty_print_macro_expansion(
|
||||||
// compile errors.
|
// compile errors.
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
struct IdentityWhenValidProcMacroExpander;
|
struct IdentityWhenValidProcMacroExpander;
|
||||||
impl base_db::ProcMacroExpander for IdentityWhenValidProcMacroExpander {
|
impl ProcMacroExpander for IdentityWhenValidProcMacroExpander {
|
||||||
fn expand(
|
fn expand(
|
||||||
&self,
|
&self,
|
||||||
subtree: &Subtree,
|
subtree: &Subtree,
|
||||||
|
@ -316,7 +322,7 @@ impl base_db::ProcMacroExpander for IdentityWhenValidProcMacroExpander {
|
||||||
_: SpanData,
|
_: SpanData,
|
||||||
_: SpanData,
|
_: SpanData,
|
||||||
_: SpanData,
|
_: SpanData,
|
||||||
) -> Result<Subtree, base_db::ProcMacroExpansionError> {
|
) -> Result<Subtree, ProcMacroExpansionError> {
|
||||||
let (parse, _) =
|
let (parse, _) =
|
||||||
::mbe::token_tree_to_syntax_node(subtree, ::mbe::TopEntryPoint::MacroItems);
|
::mbe::token_tree_to_syntax_node(subtree, ::mbe::TopEntryPoint::MacroItems);
|
||||||
if parse.errors().is_empty() {
|
if parse.errors().is_empty() {
|
||||||
|
|
|
@ -59,8 +59,11 @@ mod tests;
|
||||||
|
|
||||||
use std::{cmp::Ord, ops::Deref};
|
use std::{cmp::Ord, ops::Deref};
|
||||||
|
|
||||||
use base_db::{CrateId, Edition, FileId, ProcMacroKind};
|
use base_db::{CrateId, Edition, FileId};
|
||||||
use hir_expand::{ast_id_map::FileAstId, name::Name, HirFileId, InFile, MacroCallId, MacroDefId};
|
use hir_expand::{
|
||||||
|
ast_id_map::FileAstId, name::Name, proc_macro::ProcMacroKind, HirFileId, InFile, MacroCallId,
|
||||||
|
MacroDefId,
|
||||||
|
};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use la_arena::Arena;
|
use la_arena::Arena;
|
||||||
use profile::Count;
|
use profile::Count;
|
||||||
|
|
|
@ -15,7 +15,7 @@ use hir_expand::{
|
||||||
builtin_derive_macro::find_builtin_derive,
|
builtin_derive_macro::find_builtin_derive,
|
||||||
builtin_fn_macro::find_builtin_macro,
|
builtin_fn_macro::find_builtin_macro,
|
||||||
name::{name, AsName, Name},
|
name::{name, AsName, Name},
|
||||||
proc_macro::ProcMacroExpander,
|
proc_macro::CustomProcMacroExpander,
|
||||||
ExpandResult, ExpandTo, HirFileId, InFile, MacroCallId, MacroCallKind, MacroCallLoc,
|
ExpandResult, ExpandTo, HirFileId, InFile, MacroCallId, MacroCallKind, MacroCallLoc,
|
||||||
MacroDefId, MacroDefKind,
|
MacroDefId, MacroDefKind,
|
||||||
};
|
};
|
||||||
|
@ -95,7 +95,12 @@ pub(super) fn collect_defs(db: &dyn DefDatabase, def_map: DefMap, tree_id: TreeI
|
||||||
ctx: SyntaxContextId::ROOT,
|
ctx: SyntaxContextId::ROOT,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
(name.as_name(), ProcMacroExpander::new(base_db::ProcMacroId(idx as u32)))
|
(
|
||||||
|
name.as_name(),
|
||||||
|
CustomProcMacroExpander::new(hir_expand::proc_macro::ProcMacroId(
|
||||||
|
idx as u32,
|
||||||
|
)),
|
||||||
|
)
|
||||||
})
|
})
|
||||||
.collect())
|
.collect())
|
||||||
}
|
}
|
||||||
|
@ -253,7 +258,7 @@ struct DefCollector<'a> {
|
||||||
/// built by the build system, and is the list of proc. macros we can actually expand. It is
|
/// built by the build system, and is the list of proc. macros we can actually expand. It is
|
||||||
/// empty when proc. macro support is disabled (in which case we still do name resolution for
|
/// empty when proc. macro support is disabled (in which case we still do name resolution for
|
||||||
/// them).
|
/// them).
|
||||||
proc_macros: Result<Vec<(Name, ProcMacroExpander)>, Box<str>>,
|
proc_macros: Result<Vec<(Name, CustomProcMacroExpander)>, Box<str>>,
|
||||||
is_proc_macro: bool,
|
is_proc_macro: bool,
|
||||||
from_glob_import: PerNsGlobImports,
|
from_glob_import: PerNsGlobImports,
|
||||||
/// If we fail to resolve an attribute on a `ModItem`, we fall back to ignoring the attribute.
|
/// If we fail to resolve an attribute on a `ModItem`, we fall back to ignoring the attribute.
|
||||||
|
@ -603,7 +608,7 @@ impl DefCollector<'_> {
|
||||||
let (expander, kind) =
|
let (expander, kind) =
|
||||||
match self.proc_macros.as_ref().map(|it| it.iter().find(|(n, _)| n == &def.name)) {
|
match self.proc_macros.as_ref().map(|it| it.iter().find(|(n, _)| n == &def.name)) {
|
||||||
Ok(Some(&(_, expander))) => (expander, kind),
|
Ok(Some(&(_, expander))) => (expander, kind),
|
||||||
_ => (ProcMacroExpander::dummy(), kind),
|
_ => (CustomProcMacroExpander::dummy(), kind),
|
||||||
};
|
};
|
||||||
|
|
||||||
let proc_macro_id =
|
let proc_macro_id =
|
||||||
|
@ -2363,8 +2368,10 @@ impl ModCollector<'_, '_> {
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
|
use base_db::SourceDatabase;
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
|
|
||||||
use crate::{db::DefDatabase, test_db::TestDB};
|
use crate::{db::DefDatabase, test_db::TestDB};
|
||||||
use base_db::{fixture::WithFixture, SourceDatabase};
|
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
|
|
|
@ -19,11 +19,13 @@ pub enum ProcMacroKind {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ProcMacroKind {
|
impl ProcMacroKind {
|
||||||
pub(super) fn to_basedb_kind(&self) -> base_db::ProcMacroKind {
|
pub(super) fn to_basedb_kind(&self) -> hir_expand::proc_macro::ProcMacroKind {
|
||||||
match self {
|
match self {
|
||||||
ProcMacroKind::CustomDerive { .. } => base_db::ProcMacroKind::CustomDerive,
|
ProcMacroKind::CustomDerive { .. } => {
|
||||||
ProcMacroKind::FnLike => base_db::ProcMacroKind::FuncLike,
|
hir_expand::proc_macro::ProcMacroKind::CustomDerive
|
||||||
ProcMacroKind::Attr => base_db::ProcMacroKind::Attr,
|
}
|
||||||
|
ProcMacroKind::FnLike => hir_expand::proc_macro::ProcMacroKind::FuncLike,
|
||||||
|
ProcMacroKind::Attr => hir_expand::proc_macro::ProcMacroKind::Attr,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,8 +4,9 @@ mod macros;
|
||||||
mod mod_resolution;
|
mod mod_resolution;
|
||||||
mod primitives;
|
mod primitives;
|
||||||
|
|
||||||
use base_db::{fixture::WithFixture, SourceDatabase};
|
use base_db::SourceDatabase;
|
||||||
use expect_test::{expect, Expect};
|
use expect_test::{expect, Expect};
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
||||||
use crate::{db::DefDatabase, nameres::DefMap, test_db::TestDB};
|
use crate::{db::DefDatabase, nameres::DefMap, test_db::TestDB};
|
||||||
|
|
|
@ -32,6 +32,7 @@ profile.workspace = true
|
||||||
tt.workspace = true
|
tt.workspace = true
|
||||||
mbe.workspace = true
|
mbe.workspace = true
|
||||||
limit.workspace = true
|
limit.workspace = true
|
||||||
|
test-utils.workspace = true
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
expect-test = "1.4.0"
|
expect-test = "1.4.0"
|
||||||
|
|
|
@ -22,10 +22,12 @@ use crate::{
|
||||||
builtin_fn_macro::EagerExpander,
|
builtin_fn_macro::EagerExpander,
|
||||||
fixup::{self, reverse_fixups, SyntaxFixupUndoInfo},
|
fixup::{self, reverse_fixups, SyntaxFixupUndoInfo},
|
||||||
hygiene::{apply_mark, SyntaxContextData, Transparency},
|
hygiene::{apply_mark, SyntaxContextData, Transparency},
|
||||||
|
proc_macro::ProcMacros,
|
||||||
span::{RealSpanMap, SpanMap, SpanMapRef},
|
span::{RealSpanMap, SpanMap, SpanMapRef},
|
||||||
tt, AstId, BuiltinAttrExpander, BuiltinDeriveExpander, BuiltinFnLikeExpander, EagerCallInfo,
|
tt, AstId, BuiltinAttrExpander, BuiltinDeriveExpander, BuiltinFnLikeExpander,
|
||||||
ExpandError, ExpandResult, ExpandTo, ExpansionSpanMap, HirFileId, HirFileIdRepr, MacroCallId,
|
CustomProcMacroExpander, EagerCallInfo, ExpandError, ExpandResult, ExpandTo, ExpansionSpanMap,
|
||||||
MacroCallKind, MacroCallLoc, MacroDefId, MacroDefKind, MacroFileId, ProcMacroExpander,
|
HirFileId, HirFileIdRepr, MacroCallId, MacroCallKind, MacroCallLoc, MacroDefId, MacroDefKind,
|
||||||
|
MacroFileId,
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Total limit on the number of tokens produced by any macro invocation.
|
/// Total limit on the number of tokens produced by any macro invocation.
|
||||||
|
@ -86,11 +88,15 @@ pub enum TokenExpander {
|
||||||
/// `derive(Copy)` and such.
|
/// `derive(Copy)` and such.
|
||||||
BuiltInDerive(BuiltinDeriveExpander),
|
BuiltInDerive(BuiltinDeriveExpander),
|
||||||
/// The thing we love the most here in rust-analyzer -- procedural macros.
|
/// The thing we love the most here in rust-analyzer -- procedural macros.
|
||||||
ProcMacro(ProcMacroExpander),
|
ProcMacro(CustomProcMacroExpander),
|
||||||
}
|
}
|
||||||
|
|
||||||
#[salsa::query_group(ExpandDatabaseStorage)]
|
#[salsa::query_group(ExpandDatabaseStorage)]
|
||||||
pub trait ExpandDatabase: SourceDatabase {
|
pub trait ExpandDatabase: SourceDatabase {
|
||||||
|
/// The proc macros.
|
||||||
|
#[salsa::input]
|
||||||
|
fn proc_macros(&self) -> Arc<ProcMacros>;
|
||||||
|
|
||||||
fn ast_id_map(&self, file_id: HirFileId) -> Arc<AstIdMap>;
|
fn ast_id_map(&self, file_id: HirFileId) -> Arc<AstIdMap>;
|
||||||
|
|
||||||
/// Main public API -- parses a hir file, not caring whether it's a real
|
/// Main public API -- parses a hir file, not caring whether it's a real
|
||||||
|
|
|
@ -1,6 +1,11 @@
|
||||||
//! A set of high-level utility fixture methods to use in tests.
|
//! A set of high-level utility fixture methods to use in tests.
|
||||||
use std::{mem, str::FromStr, sync};
|
use std::{mem, ops::Not, str::FromStr, sync};
|
||||||
|
|
||||||
|
use base_db::{
|
||||||
|
salsa::Durability, span::SpanData, CrateDisplayName, CrateGraph, CrateId, CrateName,
|
||||||
|
CrateOrigin, Dependency, DependencyKind, Edition, Env, FileChange, FileId, FilePosition,
|
||||||
|
FileRange, FileSet, LangCrateOrigin, ReleaseChannel, SourceDatabaseExt, SourceRoot, VfsPath,
|
||||||
|
};
|
||||||
use cfg::CfgOptions;
|
use cfg::CfgOptions;
|
||||||
use rustc_hash::FxHashMap;
|
use rustc_hash::FxHashMap;
|
||||||
use test_utils::{
|
use test_utils::{
|
||||||
|
@ -9,19 +14,13 @@ use test_utils::{
|
||||||
};
|
};
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
use tt::{Leaf, Subtree, TokenTree};
|
use tt::{Leaf, Subtree, TokenTree};
|
||||||
use vfs::{file_set::FileSet, VfsPath};
|
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
input::{CrateName, CrateOrigin, LangCrateOrigin},
|
db::ExpandDatabase,
|
||||||
span::SpanData,
|
proc_macro::{ProcMacro, ProcMacroExpander, ProcMacroExpansionError, ProcMacros},
|
||||||
Change, CrateDisplayName, CrateGraph, CrateId, Dependency, DependencyKind, Edition, Env,
|
|
||||||
FileId, FilePosition, FileRange, ProcMacro, ProcMacroExpander, ProcMacroExpansionError,
|
|
||||||
ProcMacros, ReleaseChannel, SourceDatabaseExt, SourceRoot, SourceRootId,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
pub const WORKSPACE: SourceRootId = SourceRootId(0);
|
pub trait WithFixture: Default + ExpandDatabase + SourceDatabaseExt + 'static {
|
||||||
|
|
||||||
pub trait WithFixture: Default + SourceDatabaseExt + 'static {
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
fn with_single_file(ra_fixture: &str) -> (Self, FileId) {
|
fn with_single_file(ra_fixture: &str) -> (Self, FileId) {
|
||||||
let fixture = ChangeFixture::parse(ra_fixture);
|
let fixture = ChangeFixture::parse(ra_fixture);
|
||||||
|
@ -80,6 +79,7 @@ pub trait WithFixture: Default + SourceDatabaseExt + 'static {
|
||||||
let fixture = ChangeFixture::parse(ra_fixture);
|
let fixture = ChangeFixture::parse(ra_fixture);
|
||||||
let mut db = Self::default();
|
let mut db = Self::default();
|
||||||
fixture.change.apply(&mut db);
|
fixture.change.apply(&mut db);
|
||||||
|
|
||||||
let (file_id, range_or_offset) = fixture
|
let (file_id, range_or_offset) = fixture
|
||||||
.file_position
|
.file_position
|
||||||
.expect("Could not find file position in fixture. Did you forget to add an `$0`?");
|
.expect("Could not find file position in fixture. Did you forget to add an `$0`?");
|
||||||
|
@ -95,7 +95,42 @@ pub trait WithFixture: Default + SourceDatabaseExt + 'static {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<DB: SourceDatabaseExt + Default + 'static> WithFixture for DB {}
|
impl<DB: ExpandDatabase + SourceDatabaseExt + Default + 'static> WithFixture for DB {}
|
||||||
|
|
||||||
|
#[derive(Debug, Default)]
|
||||||
|
pub struct Change {
|
||||||
|
pub source_change: FileChange,
|
||||||
|
pub proc_macros: Option<ProcMacros>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Change {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
Self::default()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn apply(self, db: &mut (impl ExpandDatabase + SourceDatabaseExt)) {
|
||||||
|
self.source_change.apply(db);
|
||||||
|
if let Some(proc_macros) = self.proc_macros {
|
||||||
|
db.set_proc_macros_with_durability(Arc::new(proc_macros), Durability::HIGH);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn change_file(&mut self, file_id: FileId, new_text: Option<Arc<str>>) {
|
||||||
|
self.source_change.change_file(file_id, new_text)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_crate_graph(&mut self, graph: CrateGraph) {
|
||||||
|
self.source_change.set_crate_graph(graph)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_proc_macros(&mut self, proc_macros: ProcMacros) {
|
||||||
|
self.proc_macros = Some(proc_macros);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_roots(&mut self, roots: Vec<SourceRoot>) {
|
||||||
|
self.source_change.set_roots(roots)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub struct ChangeFixture {
|
pub struct ChangeFixture {
|
||||||
pub file_position: Option<(FileId, RangeOrOffset)>,
|
pub file_position: Option<(FileId, RangeOrOffset)>,
|
||||||
|
@ -122,7 +157,7 @@ impl ChangeFixture {
|
||||||
.unwrap_or_else(|| panic!("unknown release channel found: {it}"))
|
.unwrap_or_else(|| panic!("unknown release channel found: {it}"))
|
||||||
})
|
})
|
||||||
.unwrap_or(ReleaseChannel::Stable);
|
.unwrap_or(ReleaseChannel::Stable);
|
||||||
let mut change = Change::new();
|
let mut source_change = FileChange::new();
|
||||||
|
|
||||||
let mut files = Vec::new();
|
let mut files = Vec::new();
|
||||||
let mut crate_graph = CrateGraph::default();
|
let mut crate_graph = CrateGraph::default();
|
||||||
|
@ -206,7 +241,7 @@ impl ChangeFixture {
|
||||||
default_target_data_layout = meta.target_data_layout;
|
default_target_data_layout = meta.target_data_layout;
|
||||||
}
|
}
|
||||||
|
|
||||||
change.change_file(file_id, Some(Arc::from(text)));
|
source_change.change_file(file_id, Some(Arc::from(text)));
|
||||||
let path = VfsPath::new_virtual_path(meta.path);
|
let path = VfsPath::new_virtual_path(meta.path);
|
||||||
file_set.insert(file_id, path);
|
file_set.insert(file_id, path);
|
||||||
files.push(file_id);
|
files.push(file_id);
|
||||||
|
@ -261,7 +296,7 @@ impl ChangeFixture {
|
||||||
fs.insert(core_file, VfsPath::new_virtual_path("/sysroot/core/lib.rs".to_string()));
|
fs.insert(core_file, VfsPath::new_virtual_path("/sysroot/core/lib.rs".to_string()));
|
||||||
roots.push(SourceRoot::new_library(fs));
|
roots.push(SourceRoot::new_library(fs));
|
||||||
|
|
||||||
change.change_file(core_file, Some(Arc::from(mini_core.source_code())));
|
source_change.change_file(core_file, Some(Arc::from(mini_core.source_code())));
|
||||||
|
|
||||||
let all_crates = crate_graph.crates_in_topological_order();
|
let all_crates = crate_graph.crates_in_topological_order();
|
||||||
|
|
||||||
|
@ -306,7 +341,7 @@ impl ChangeFixture {
|
||||||
);
|
);
|
||||||
roots.push(SourceRoot::new_library(fs));
|
roots.push(SourceRoot::new_library(fs));
|
||||||
|
|
||||||
change.change_file(proc_lib_file, Some(Arc::from(source)));
|
source_change.change_file(proc_lib_file, Some(Arc::from(source)));
|
||||||
|
|
||||||
let all_crates = crate_graph.crates_in_topological_order();
|
let all_crates = crate_graph.crates_in_topological_order();
|
||||||
|
|
||||||
|
@ -344,11 +379,17 @@ impl ChangeFixture {
|
||||||
SourceRootKind::Library => SourceRoot::new_library(mem::take(&mut file_set)),
|
SourceRootKind::Library => SourceRoot::new_library(mem::take(&mut file_set)),
|
||||||
};
|
};
|
||||||
roots.push(root);
|
roots.push(root);
|
||||||
change.set_roots(roots);
|
source_change.set_roots(roots);
|
||||||
change.set_crate_graph(crate_graph);
|
source_change.set_crate_graph(crate_graph);
|
||||||
change.set_proc_macros(proc_macros);
|
|
||||||
|
|
||||||
ChangeFixture { file_position, files, change }
|
ChangeFixture {
|
||||||
|
file_position,
|
||||||
|
files,
|
||||||
|
change: Change {
|
||||||
|
source_change,
|
||||||
|
proc_macros: proc_macros.is_empty().not().then(|| proc_macros),
|
||||||
|
},
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,20 +6,21 @@
|
||||||
|
|
||||||
#![warn(rust_2018_idioms, unused_lifetimes)]
|
#![warn(rust_2018_idioms, unused_lifetimes)]
|
||||||
|
|
||||||
pub mod db;
|
|
||||||
pub mod ast_id_map;
|
pub mod ast_id_map;
|
||||||
pub mod name;
|
pub mod attrs;
|
||||||
pub mod hygiene;
|
|
||||||
pub mod builtin_attr_macro;
|
pub mod builtin_attr_macro;
|
||||||
pub mod builtin_derive_macro;
|
pub mod builtin_derive_macro;
|
||||||
pub mod builtin_fn_macro;
|
pub mod builtin_fn_macro;
|
||||||
|
pub mod db;
|
||||||
|
pub mod eager;
|
||||||
|
pub mod files;
|
||||||
|
pub mod fixture;
|
||||||
|
pub mod hygiene;
|
||||||
|
pub mod mod_path;
|
||||||
|
pub mod name;
|
||||||
pub mod proc_macro;
|
pub mod proc_macro;
|
||||||
pub mod quote;
|
pub mod quote;
|
||||||
pub mod eager;
|
|
||||||
pub mod mod_path;
|
|
||||||
pub mod attrs;
|
|
||||||
pub mod span;
|
pub mod span;
|
||||||
pub mod files;
|
|
||||||
mod fixup;
|
mod fixup;
|
||||||
|
|
||||||
use attrs::collect_attrs;
|
use attrs::collect_attrs;
|
||||||
|
@ -29,7 +30,7 @@ use std::{fmt, hash::Hash};
|
||||||
|
|
||||||
use base_db::{
|
use base_db::{
|
||||||
span::{HirFileIdRepr, SpanData, SyntaxContextId},
|
span::{HirFileIdRepr, SpanData, SyntaxContextId},
|
||||||
CrateId, FileId, FileRange, ProcMacroKind,
|
CrateId, FileId, FileRange,
|
||||||
};
|
};
|
||||||
use either::Either;
|
use either::Either;
|
||||||
use syntax::{
|
use syntax::{
|
||||||
|
@ -45,7 +46,7 @@ use crate::{
|
||||||
db::TokenExpander,
|
db::TokenExpander,
|
||||||
fixup::SyntaxFixupUndoInfo,
|
fixup::SyntaxFixupUndoInfo,
|
||||||
mod_path::ModPath,
|
mod_path::ModPath,
|
||||||
proc_macro::ProcMacroExpander,
|
proc_macro::{CustomProcMacroExpander, ProcMacroKind},
|
||||||
span::{ExpansionSpanMap, SpanMap},
|
span::{ExpansionSpanMap, SpanMap},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -138,7 +139,7 @@ pub enum MacroDefKind {
|
||||||
BuiltInAttr(BuiltinAttrExpander, AstId<ast::Macro>),
|
BuiltInAttr(BuiltinAttrExpander, AstId<ast::Macro>),
|
||||||
BuiltInDerive(BuiltinDeriveExpander, AstId<ast::Macro>),
|
BuiltInDerive(BuiltinDeriveExpander, AstId<ast::Macro>),
|
||||||
BuiltInEager(EagerExpander, AstId<ast::Macro>),
|
BuiltInEager(EagerExpander, AstId<ast::Macro>),
|
||||||
ProcMacro(ProcMacroExpander, ProcMacroKind, AstId<ast::Fn>),
|
ProcMacro(CustomProcMacroExpander, ProcMacroKind, AstId<ast::Fn>),
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
|
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
|
||||||
|
|
|
@ -1,18 +1,63 @@
|
||||||
//! Proc Macro Expander stub
|
//! Proc Macro Expander stub
|
||||||
|
|
||||||
use base_db::{span::SpanData, CrateId, ProcMacroExpansionError, ProcMacroId, ProcMacroKind};
|
use core::fmt;
|
||||||
|
use std::{panic::RefUnwindSafe, sync};
|
||||||
|
|
||||||
|
use base_db::{span::SpanData, CrateId, Env};
|
||||||
|
use rustc_hash::FxHashMap;
|
||||||
use stdx::never;
|
use stdx::never;
|
||||||
|
use syntax::SmolStr;
|
||||||
|
|
||||||
use crate::{db::ExpandDatabase, tt, ExpandError, ExpandResult};
|
use crate::{db::ExpandDatabase, tt, ExpandError, ExpandResult};
|
||||||
|
|
||||||
|
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
|
||||||
|
pub struct ProcMacroId(pub u32);
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Eq, PartialEq, Debug, Hash)]
|
||||||
|
pub enum ProcMacroKind {
|
||||||
|
CustomDerive,
|
||||||
|
FuncLike,
|
||||||
|
Attr,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait ProcMacroExpander: fmt::Debug + Send + Sync + RefUnwindSafe {
|
||||||
|
fn expand(
|
||||||
|
&self,
|
||||||
|
subtree: &tt::Subtree,
|
||||||
|
attrs: Option<&tt::Subtree>,
|
||||||
|
env: &Env,
|
||||||
|
def_site: SpanData,
|
||||||
|
call_site: SpanData,
|
||||||
|
mixed_site: SpanData,
|
||||||
|
) -> Result<tt::Subtree, ProcMacroExpansionError>;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub enum ProcMacroExpansionError {
|
||||||
|
Panic(String),
|
||||||
|
/// Things like "proc macro server was killed by OOM".
|
||||||
|
System(String),
|
||||||
|
}
|
||||||
|
|
||||||
|
pub type ProcMacroLoadResult = Result<Vec<ProcMacro>, String>;
|
||||||
|
|
||||||
|
pub type ProcMacros = FxHashMap<CrateId, ProcMacroLoadResult>;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone)]
|
||||||
|
pub struct ProcMacro {
|
||||||
|
pub name: SmolStr,
|
||||||
|
pub kind: ProcMacroKind,
|
||||||
|
pub expander: sync::Arc<dyn ProcMacroExpander>,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash)]
|
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash)]
|
||||||
pub struct ProcMacroExpander {
|
pub struct CustomProcMacroExpander {
|
||||||
proc_macro_id: ProcMacroId,
|
proc_macro_id: ProcMacroId,
|
||||||
}
|
}
|
||||||
|
|
||||||
const DUMMY_ID: u32 = !0;
|
const DUMMY_ID: u32 = !0;
|
||||||
|
|
||||||
impl ProcMacroExpander {
|
impl CustomProcMacroExpander {
|
||||||
pub fn new(proc_macro_id: ProcMacroId) -> Self {
|
pub fn new(proc_macro_id: ProcMacroId) -> Self {
|
||||||
assert_ne!(proc_macro_id.0, DUMMY_ID);
|
assert_ne!(proc_macro_id.0, DUMMY_ID);
|
||||||
Self { proc_macro_id }
|
Self { proc_macro_id }
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
use base_db::{fixture::WithFixture, FileId};
|
use base_db::FileId;
|
||||||
use chalk_ir::Substitution;
|
use chalk_ir::Substitution;
|
||||||
use hir_def::db::DefDatabase;
|
use hir_def::db::DefDatabase;
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
use test_utils::skip_slow_tests;
|
use test_utils::skip_slow_tests;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
|
||||||
use base_db::fixture::WithFixture;
|
|
||||||
use chalk_ir::{AdtId, TyKind};
|
use chalk_ir::{AdtId, TyKind};
|
||||||
use either::Either;
|
use either::Either;
|
||||||
use hir_def::db::DefDatabase;
|
use hir_def::db::DefDatabase;
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
use base_db::{fixture::WithFixture, FileId};
|
use base_db::FileId;
|
||||||
use hir_def::db::DefDatabase;
|
use hir_def::db::DefDatabase;
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
use syntax::{TextRange, TextSize};
|
use syntax::{TextRange, TextSize};
|
||||||
|
|
||||||
use crate::{db::HirDatabase, test_db::TestDB, Interner, Substitution};
|
use crate::{db::HirDatabase, test_db::TestDB, Interner, Substitution};
|
||||||
|
|
|
@ -12,7 +12,7 @@ mod diagnostics;
|
||||||
|
|
||||||
use std::{collections::HashMap, env};
|
use std::{collections::HashMap, env};
|
||||||
|
|
||||||
use base_db::{fixture::WithFixture, FileRange, SourceDatabaseExt};
|
use base_db::{FileRange, SourceDatabaseExt};
|
||||||
use expect_test::Expect;
|
use expect_test::Expect;
|
||||||
use hir_def::{
|
use hir_def::{
|
||||||
body::{Body, BodySourceMap, SyntheticSyntax},
|
body::{Body, BodySourceMap, SyntheticSyntax},
|
||||||
|
@ -23,7 +23,7 @@ use hir_def::{
|
||||||
src::HasSource,
|
src::HasSource,
|
||||||
AssocItemId, DefWithBodyId, HasModule, LocalModuleId, Lookup, ModuleDefId,
|
AssocItemId, DefWithBodyId, HasModule, LocalModuleId, Lookup, ModuleDefId,
|
||||||
};
|
};
|
||||||
use hir_expand::{db::ExpandDatabase, InFile};
|
use hir_expand::{db::ExpandDatabase, fixture::WithFixture, InFile};
|
||||||
use once_cell::race::OnceBool;
|
use once_cell::race::OnceBool;
|
||||||
use stdx::format_to;
|
use stdx::format_to;
|
||||||
use syntax::{
|
use syntax::{
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
use base_db::{fixture::WithFixture, SourceDatabaseExt};
|
use base_db::SourceDatabaseExt;
|
||||||
|
use hir_expand::fixture::WithFixture;
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
||||||
use crate::{db::HirDatabase, test_db::TestDB};
|
use crate::{db::HirDatabase, test_db::TestDB};
|
||||||
|
|
|
@ -24,6 +24,6 @@ pub use hir_def::db::{
|
||||||
pub use hir_expand::db::{
|
pub use hir_expand::db::{
|
||||||
AstIdMapQuery, DeclMacroExpanderQuery, ExpandDatabase, ExpandDatabaseStorage,
|
AstIdMapQuery, DeclMacroExpanderQuery, ExpandDatabase, ExpandDatabaseStorage,
|
||||||
ExpandProcMacroQuery, InternMacroCallQuery, InternSyntaxContextQuery, MacroArgQuery,
|
ExpandProcMacroQuery, InternMacroCallQuery, InternSyntaxContextQuery, MacroArgQuery,
|
||||||
ParseMacroExpansionErrorQuery, ParseMacroExpansionQuery, RealSpanMapQuery,
|
ParseMacroExpansionErrorQuery, ParseMacroExpansionQuery, ProcMacrosQuery, RealSpanMapQuery,
|
||||||
};
|
};
|
||||||
pub use hir_ty::db::*;
|
pub use hir_ty::db::*;
|
||||||
|
|
|
@ -37,7 +37,7 @@ mod display;
|
||||||
use std::{iter, mem::discriminant, ops::ControlFlow};
|
use std::{iter, mem::discriminant, ops::ControlFlow};
|
||||||
|
|
||||||
use arrayvec::ArrayVec;
|
use arrayvec::ArrayVec;
|
||||||
use base_db::{CrateDisplayName, CrateId, CrateOrigin, Edition, FileId, ProcMacroKind};
|
use base_db::{CrateDisplayName, CrateId, CrateOrigin, Edition, FileId};
|
||||||
use either::Either;
|
use either::Either;
|
||||||
use hir_def::{
|
use hir_def::{
|
||||||
body::{BodyDiagnostic, SyntheticSyntax},
|
body::{BodyDiagnostic, SyntheticSyntax},
|
||||||
|
@ -59,7 +59,7 @@ use hir_def::{
|
||||||
Lookup, MacroExpander, MacroId, ModuleId, StaticId, StructId, TraitAliasId, TraitId,
|
Lookup, MacroExpander, MacroId, ModuleId, StaticId, StructId, TraitAliasId, TraitId,
|
||||||
TypeAliasId, TypeOrConstParamId, TypeParamId, UnionId,
|
TypeAliasId, TypeOrConstParamId, TypeParamId, UnionId,
|
||||||
};
|
};
|
||||||
use hir_expand::{attrs::collect_attrs, name::name, MacroCallKind};
|
use hir_expand::{attrs::collect_attrs, name::name, proc_macro::ProcMacroKind, MacroCallKind};
|
||||||
use hir_ty::{
|
use hir_ty::{
|
||||||
all_super_traits, autoderef, check_orphan_rules,
|
all_super_traits, autoderef, check_orphan_rules,
|
||||||
consteval::{try_const_usize, unknown_const_as_generic, ConstEvalError, ConstExt},
|
consteval::{try_const_usize, unknown_const_as_generic, ConstEvalError, ConstExt},
|
||||||
|
@ -125,8 +125,10 @@ pub use {
|
||||||
},
|
},
|
||||||
hir_expand::{
|
hir_expand::{
|
||||||
attrs::{Attr, AttrId},
|
attrs::{Attr, AttrId},
|
||||||
|
fixture::{Change, ChangeFixture, WithFixture},
|
||||||
hygiene::{marks_rev, SyntaxContextExt},
|
hygiene::{marks_rev, SyntaxContextExt},
|
||||||
name::{known, Name},
|
name::{known, Name},
|
||||||
|
proc_macro::ProcMacros,
|
||||||
tt, ExpandResult, HirFileId, HirFileIdExt, InFile, InMacroFile, InRealFile, MacroFileId,
|
tt, ExpandResult, HirFileId, HirFileIdExt, InFile, InMacroFile, InRealFile, MacroFileId,
|
||||||
MacroFileIdExt,
|
MacroFileIdExt,
|
||||||
},
|
},
|
||||||
|
|
|
@ -280,12 +280,8 @@ fn module_distance_heuristic(db: &dyn HirDatabase, current: &Module, item: &Modu
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
use hir::Semantics;
|
use hir::{Semantics, WithFixture};
|
||||||
use ide_db::{
|
use ide_db::{assists::AssistResolveStrategy, base_db::FileRange, RootDatabase};
|
||||||
assists::AssistResolveStrategy,
|
|
||||||
base_db::{fixture::WithFixture, FileRange},
|
|
||||||
RootDatabase,
|
|
||||||
};
|
|
||||||
|
|
||||||
use crate::tests::{
|
use crate::tests::{
|
||||||
check_assist, check_assist_by_label, check_assist_not_applicable, check_assist_target,
|
check_assist, check_assist_by_label, check_assist_not_applicable, check_assist_target,
|
||||||
|
|
|
@ -3,9 +3,9 @@ mod generated;
|
||||||
mod sourcegen;
|
mod sourcegen;
|
||||||
|
|
||||||
use expect_test::expect;
|
use expect_test::expect;
|
||||||
use hir::Semantics;
|
use hir::{Semantics, WithFixture};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{fixture::WithFixture, FileId, FileRange, SourceDatabaseExt},
|
base_db::{FileId, FileRange, SourceDatabaseExt},
|
||||||
imports::insert_use::{ImportGranularity, InsertUseConfig},
|
imports::insert_use::{ImportGranularity, InsertUseConfig},
|
||||||
source_change::FileSystemEdit,
|
source_change::FileSystemEdit,
|
||||||
RootDatabase, SnippetCap,
|
RootDatabase, SnippetCap,
|
||||||
|
|
|
@ -275,7 +275,8 @@ fn from_field_name(expr: &ast::Expr) -> Option<String> {
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use ide_db::base_db::{fixture::WithFixture, FileRange};
|
use hir::WithFixture;
|
||||||
|
use ide_db::base_db::FileRange;
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
|
|
|
@ -24,9 +24,9 @@ mod use_tree;
|
||||||
mod visibility;
|
mod visibility;
|
||||||
|
|
||||||
use expect_test::Expect;
|
use expect_test::Expect;
|
||||||
use hir::PrefixKind;
|
use hir::{ChangeFixture, PrefixKind};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{fixture::ChangeFixture, FileLoader, FilePosition},
|
base_db::{FileLoader, FilePosition},
|
||||||
imports::insert_use::{ImportGranularity, InsertUseConfig},
|
imports::insert_use::{ImportGranularity, InsertUseConfig},
|
||||||
RootDatabase, SnippetCap,
|
RootDatabase, SnippetCap,
|
||||||
};
|
};
|
||||||
|
|
|
@ -5,13 +5,13 @@ use base_db::{
|
||||||
debug::{DebugQueryTable, TableEntry},
|
debug::{DebugQueryTable, TableEntry},
|
||||||
Database, Durability, Query, QueryTable,
|
Database, Durability, Query, QueryTable,
|
||||||
},
|
},
|
||||||
Change, SourceRootId,
|
SourceRootId,
|
||||||
};
|
};
|
||||||
use profile::{memory_usage, Bytes};
|
use profile::{memory_usage, Bytes};
|
||||||
use rustc_hash::FxHashSet;
|
use rustc_hash::FxHashSet;
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
||||||
use crate::{symbol_index::SymbolsDatabase, RootDatabase};
|
use crate::{fixture::Change, symbol_index::SymbolsDatabase, RootDatabase};
|
||||||
|
|
||||||
impl RootDatabase {
|
impl RootDatabase {
|
||||||
pub fn request_cancellation(&mut self) {
|
pub fn request_cancellation(&mut self) {
|
||||||
|
@ -23,7 +23,7 @@ impl RootDatabase {
|
||||||
let _p = profile::span("RootDatabase::apply_change");
|
let _p = profile::span("RootDatabase::apply_change");
|
||||||
self.request_cancellation();
|
self.request_cancellation();
|
||||||
tracing::trace!("apply_change {:?}", change);
|
tracing::trace!("apply_change {:?}", change);
|
||||||
if let Some(roots) = &change.roots {
|
if let Some(roots) = &change.source_change.roots {
|
||||||
let mut local_roots = FxHashSet::default();
|
let mut local_roots = FxHashSet::default();
|
||||||
let mut library_roots = FxHashSet::default();
|
let mut library_roots = FxHashSet::default();
|
||||||
for (idx, root) in roots.iter().enumerate() {
|
for (idx, root) in roots.iter().enumerate() {
|
||||||
|
@ -87,7 +87,6 @@ impl RootDatabase {
|
||||||
// SourceDatabase
|
// SourceDatabase
|
||||||
base_db::ParseQuery
|
base_db::ParseQuery
|
||||||
base_db::CrateGraphQuery
|
base_db::CrateGraphQuery
|
||||||
base_db::ProcMacrosQuery
|
|
||||||
|
|
||||||
// SourceDatabaseExt
|
// SourceDatabaseExt
|
||||||
base_db::FileTextQuery
|
base_db::FileTextQuery
|
||||||
|
@ -104,6 +103,7 @@ impl RootDatabase {
|
||||||
hir::db::MacroArgQuery
|
hir::db::MacroArgQuery
|
||||||
hir::db::ParseMacroExpansionQuery
|
hir::db::ParseMacroExpansionQuery
|
||||||
hir::db::RealSpanMapQuery
|
hir::db::RealSpanMapQuery
|
||||||
|
hir::db::ProcMacrosQuery
|
||||||
|
|
||||||
// DefDatabase
|
// DefDatabase
|
||||||
hir::db::FileItemTreeQuery
|
hir::db::FileItemTreeQuery
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
use base_db::fixture::WithFixture;
|
use hir::{PrefixKind, WithFixture};
|
||||||
use hir::PrefixKind;
|
|
||||||
use stdx::trim_indent;
|
use stdx::trim_indent;
|
||||||
use test_utils::{assert_eq_text, CURSOR_MARKER};
|
use test_utils::{assert_eq_text, CURSOR_MARKER};
|
||||||
|
|
||||||
|
|
|
@ -43,6 +43,11 @@ pub mod syntax_helpers {
|
||||||
pub use parser::LexedStr;
|
pub use parser::LexedStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub mod fixture {
|
||||||
|
pub use hir::{Change, ChangeFixture, WithFixture};
|
||||||
|
pub const WORKSPACE: base_db::SourceRootId = base_db::SourceRootId(0);
|
||||||
|
}
|
||||||
|
|
||||||
use std::{fmt, mem::ManuallyDrop};
|
use std::{fmt, mem::ManuallyDrop};
|
||||||
|
|
||||||
use base_db::{
|
use base_db::{
|
||||||
|
|
|
@ -378,9 +378,8 @@ impl Query {
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
|
|
||||||
use base_db::fixture::WithFixture;
|
|
||||||
use expect_test::expect_file;
|
use expect_test::expect_file;
|
||||||
use hir::symbols::SymbolCollector;
|
use hir::{symbols::SymbolCollector, WithFixture};
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
|
|
|
@ -113,9 +113,9 @@ fn assoc_item_of_trait(
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use base_db::{fixture::ChangeFixture, FilePosition};
|
use base_db::FilePosition;
|
||||||
use expect_test::{expect, Expect};
|
use expect_test::{expect, Expect};
|
||||||
use hir::Semantics;
|
use hir::{ChangeFixture, Semantics};
|
||||||
use syntax::ast::{self, AstNode};
|
use syntax::ast::{self, AstNode};
|
||||||
|
|
||||||
use crate::RootDatabase;
|
use crate::RootDatabase;
|
||||||
|
|
|
@ -2,10 +2,9 @@
|
||||||
mod sourcegen;
|
mod sourcegen;
|
||||||
|
|
||||||
use expect_test::Expect;
|
use expect_test::Expect;
|
||||||
|
use hir::WithFixture;
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
assists::AssistResolveStrategy,
|
assists::AssistResolveStrategy, base_db::SourceDatabaseExt, LineIndexDatabase, RootDatabase,
|
||||||
base_db::{fixture::WithFixture, SourceDatabaseExt},
|
|
||||||
LineIndexDatabase, RootDatabase,
|
|
||||||
};
|
};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use stdx::trim_indent;
|
use stdx::trim_indent;
|
||||||
|
|
|
@ -65,7 +65,7 @@ fn parser_undefined_placeholder_in_replacement() {
|
||||||
/// `code` may optionally contain a cursor marker `$0`. If it doesn't, then the position will be
|
/// `code` may optionally contain a cursor marker `$0`. If it doesn't, then the position will be
|
||||||
/// the start of the file. If there's a second cursor marker, then we'll return a single range.
|
/// the start of the file. If there's a second cursor marker, then we'll return a single range.
|
||||||
pub(crate) fn single_file(code: &str) -> (ide_db::RootDatabase, FilePosition, Vec<FileRange>) {
|
pub(crate) fn single_file(code: &str) -> (ide_db::RootDatabase, FilePosition, Vec<FileRange>) {
|
||||||
use ide_db::base_db::fixture::WithFixture;
|
use hir::WithFixture;
|
||||||
use ide_db::symbol_index::SymbolsDatabase;
|
use ide_db::symbol_index::SymbolsDatabase;
|
||||||
let (mut db, file_id, range_or_offset) = if code.contains(test_utils::CURSOR_MARKER) {
|
let (mut db, file_id, range_or_offset) = if code.contains(test_utils::CURSOR_MARKER) {
|
||||||
ide_db::RootDatabase::with_range_or_offset(code)
|
ide_db::RootDatabase::with_range_or_offset(code)
|
||||||
|
@ -86,7 +86,7 @@ pub(crate) fn single_file(code: &str) -> (ide_db::RootDatabase, FilePosition, Ve
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let mut local_roots = FxHashSet::default();
|
let mut local_roots = FxHashSet::default();
|
||||||
local_roots.insert(ide_db::base_db::fixture::WORKSPACE);
|
local_roots.insert(ide_db::fixture::WORKSPACE);
|
||||||
db.set_local_roots_with_durability(Arc::new(local_roots), Durability::HIGH);
|
db.set_local_roots_with_durability(Arc::new(local_roots), Durability::HIGH);
|
||||||
(db, position, selections)
|
(db, position, selections)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
//! Utilities for creating `Analysis` instances for tests.
|
//! Utilities for creating `Analysis` instances for tests.
|
||||||
use ide_db::base_db::fixture::ChangeFixture;
|
use ide_db::fixture::ChangeFixture;
|
||||||
use test_utils::{extract_annotations, RangeOrOffset};
|
use test_utils::{extract_annotations, RangeOrOffset};
|
||||||
|
|
||||||
use crate::{Analysis, AnalysisHost, FileId, FilePosition, FileRange};
|
use crate::{Analysis, AnalysisHost, FileId, FilePosition, FileRange};
|
||||||
|
|
|
@ -67,6 +67,7 @@ use std::ffi::OsStr;
|
||||||
|
|
||||||
use cfg::CfgOptions;
|
use cfg::CfgOptions;
|
||||||
use fetch_crates::CrateInfo;
|
use fetch_crates::CrateInfo;
|
||||||
|
use hir::Change;
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{
|
base_db::{
|
||||||
salsa::{self, ParallelDatabase},
|
salsa::{self, ParallelDatabase},
|
||||||
|
@ -122,7 +123,7 @@ pub use ide_completion::{
|
||||||
};
|
};
|
||||||
pub use ide_db::{
|
pub use ide_db::{
|
||||||
base_db::{
|
base_db::{
|
||||||
Cancelled, Change, CrateGraph, CrateId, Edition, FileId, FilePosition, FileRange,
|
Cancelled, CrateGraph, CrateId, Edition, FileChange, FileId, FilePosition, FileRange,
|
||||||
SourceRoot, SourceRootId,
|
SourceRoot, SourceRootId,
|
||||||
},
|
},
|
||||||
documentation::Documentation,
|
documentation::Documentation,
|
||||||
|
@ -183,7 +184,7 @@ impl AnalysisHost {
|
||||||
/// Applies changes to the current state of the world. If there are
|
/// Applies changes to the current state of the world. If there are
|
||||||
/// outstanding snapshots, they will be canceled.
|
/// outstanding snapshots, they will be canceled.
|
||||||
pub fn apply_change(&mut self, change: Change) {
|
pub fn apply_change(&mut self, change: Change) {
|
||||||
self.db.apply_change(change)
|
self.db.apply_change(change);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// NB: this clears the database
|
/// NB: this clears the database
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
|
use hir::{db::ExpandDatabase, ProcMacros};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{salsa::Durability, CrateGraph, ProcMacros, SourceDatabase},
|
base_db::{salsa::Durability, CrateGraph, SourceDatabase},
|
||||||
FxHashMap, RootDatabase,
|
FxHashMap, RootDatabase,
|
||||||
};
|
};
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
|
@ -646,7 +646,7 @@ mod tests {
|
||||||
use std::iter;
|
use std::iter;
|
||||||
|
|
||||||
use expect_test::{expect, Expect};
|
use expect_test::{expect, Expect};
|
||||||
use ide_db::base_db::{fixture::ChangeFixture, FilePosition};
|
use ide_db::{base_db::FilePosition, fixture::ChangeFixture};
|
||||||
use stdx::format_to;
|
use stdx::format_to;
|
||||||
|
|
||||||
use crate::RootDatabase;
|
use crate::RootDatabase;
|
||||||
|
|
|
@ -59,7 +59,8 @@ mod tests {
|
||||||
use expect_test::expect;
|
use expect_test::expect;
|
||||||
use ide_assists::{Assist, AssistResolveStrategy};
|
use ide_assists::{Assist, AssistResolveStrategy};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{fixture::WithFixture, salsa::Durability, FileRange},
|
base_db::{salsa::Durability, FileRange},
|
||||||
|
fixture::WithFixture,
|
||||||
symbol_index::SymbolsDatabase,
|
symbol_index::SymbolsDatabase,
|
||||||
FxHashSet, RootDatabase,
|
FxHashSet, RootDatabase,
|
||||||
};
|
};
|
||||||
|
@ -70,7 +71,7 @@ mod tests {
|
||||||
fn get_assists(ra_fixture: &str, resolve: AssistResolveStrategy) -> Vec<Assist> {
|
fn get_assists(ra_fixture: &str, resolve: AssistResolveStrategy) -> Vec<Assist> {
|
||||||
let (mut db, file_id, range_or_offset) = RootDatabase::with_range_or_offset(ra_fixture);
|
let (mut db, file_id, range_or_offset) = RootDatabase::with_range_or_offset(ra_fixture);
|
||||||
let mut local_roots = FxHashSet::default();
|
let mut local_roots = FxHashSet::default();
|
||||||
local_roots.insert(ide_db::base_db::fixture::WORKSPACE);
|
local_roots.insert(ide_db::fixture::WORKSPACE);
|
||||||
db.set_local_roots_with_durability(Arc::new(local_roots), Durability::HIGH);
|
db.set_local_roots_with_durability(Arc::new(local_roots), Durability::HIGH);
|
||||||
ssr_assists(&db, &resolve, FileRange { file_id, range: range_or_offset.into() })
|
ssr_assists(&db, &resolve, FileRange { file_id, range: range_or_offset.into() })
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,3 +23,5 @@ project-model.workspace = true
|
||||||
tt.workspace = true
|
tt.workspace = true
|
||||||
vfs.workspace = true
|
vfs.workspace = true
|
||||||
vfs-notify.workspace = true
|
vfs-notify.workspace = true
|
||||||
|
|
||||||
|
hir-expand.workspace = true
|
||||||
|
|
|
@ -5,12 +5,14 @@
|
||||||
use std::{collections::hash_map::Entry, mem, path::Path, sync};
|
use std::{collections::hash_map::Entry, mem, path::Path, sync};
|
||||||
|
|
||||||
use crossbeam_channel::{unbounded, Receiver};
|
use crossbeam_channel::{unbounded, Receiver};
|
||||||
use ide::{AnalysisHost, Change, SourceRoot};
|
use hir_expand::proc_macro::{
|
||||||
|
ProcMacro, ProcMacroExpander, ProcMacroExpansionError, ProcMacroKind, ProcMacroLoadResult,
|
||||||
|
ProcMacros,
|
||||||
|
};
|
||||||
|
use ide::{AnalysisHost, SourceRoot};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{
|
base_db::{span::SpanData, CrateGraph, Env},
|
||||||
span::SpanData, CrateGraph, Env, ProcMacro, ProcMacroExpander, ProcMacroExpansionError,
|
fixture::Change,
|
||||||
ProcMacroKind, ProcMacroLoadResult, ProcMacros,
|
|
||||||
},
|
|
||||||
FxHashMap,
|
FxHashMap,
|
||||||
};
|
};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
|
|
|
@ -4,8 +4,8 @@ use std::{
|
||||||
cell::RefCell, collections::HashMap, fs::read_to_string, panic::AssertUnwindSafe, path::PathBuf,
|
cell::RefCell, collections::HashMap, fs::read_to_string, panic::AssertUnwindSafe, path::PathBuf,
|
||||||
};
|
};
|
||||||
|
|
||||||
use hir::Crate;
|
use hir::{Change, Crate};
|
||||||
use ide::{AnalysisHost, Change, DiagnosticCode, DiagnosticsConfig};
|
use ide::{AnalysisHost, DiagnosticCode, DiagnosticsConfig};
|
||||||
use profile::StopWatch;
|
use profile::StopWatch;
|
||||||
use project_model::{CargoConfig, ProjectWorkspace, RustLibSource, Sysroot};
|
use project_model::{CargoConfig, ProjectWorkspace, RustLibSource, Sysroot};
|
||||||
|
|
||||||
|
|
|
@ -278,7 +278,7 @@ fn token_to_symbol(token: &TokenStaticData) -> Option<scip_types::Symbol> {
|
||||||
mod test {
|
mod test {
|
||||||
use super::*;
|
use super::*;
|
||||||
use ide::{AnalysisHost, FilePosition, StaticIndex, TextSize};
|
use ide::{AnalysisHost, FilePosition, StaticIndex, TextSize};
|
||||||
use ide_db::base_db::fixture::ChangeFixture;
|
use ide_db::fixture::ChangeFixture;
|
||||||
use scip::symbol::format_symbol;
|
use scip::symbol::format_symbol;
|
||||||
|
|
||||||
fn position(ra_fixture: &str) -> (AnalysisHost, FilePosition) {
|
fn position(ra_fixture: &str) -> (AnalysisHost, FilePosition) {
|
||||||
|
|
|
@ -7,7 +7,8 @@ use std::time::Instant;
|
||||||
|
|
||||||
use crossbeam_channel::{unbounded, Receiver, Sender};
|
use crossbeam_channel::{unbounded, Receiver, Sender};
|
||||||
use flycheck::FlycheckHandle;
|
use flycheck::FlycheckHandle;
|
||||||
use ide::{Analysis, AnalysisHost, Cancellable, Change, FileId};
|
use hir::Change;
|
||||||
|
use ide::{Analysis, AnalysisHost, Cancellable, FileId};
|
||||||
use ide_db::base_db::{CrateId, FileLoader, ProcMacroPaths, SourceDatabase};
|
use ide_db::base_db::{CrateId, FileLoader, ProcMacroPaths, SourceDatabase};
|
||||||
use load_cargo::SourceRootConfig;
|
use load_cargo::SourceRootConfig;
|
||||||
use lsp_types::{SemanticTokens, Url};
|
use lsp_types::{SemanticTokens, Url};
|
||||||
|
|
|
@ -10,7 +10,8 @@
|
||||||
//! in release mode in VS Code. There's however "rust-analyzer: Copy Run Command Line"
|
//! in release mode in VS Code. There's however "rust-analyzer: Copy Run Command Line"
|
||||||
//! which you can use to paste the command in terminal and add `--release` manually.
|
//! which you can use to paste the command in terminal and add `--release` manually.
|
||||||
|
|
||||||
use ide::{CallableSnippets, Change, CompletionConfig, FilePosition, TextSize};
|
use hir::Change;
|
||||||
|
use ide::{CallableSnippets, CompletionConfig, FilePosition, TextSize};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
imports::insert_use::{ImportGranularity, InsertUseConfig},
|
imports::insert_use::{ImportGranularity, InsertUseConfig},
|
||||||
SnippetCap,
|
SnippetCap,
|
||||||
|
|
|
@ -16,10 +16,9 @@
|
||||||
use std::{iter, mem};
|
use std::{iter, mem};
|
||||||
|
|
||||||
use flycheck::{FlycheckConfig, FlycheckHandle};
|
use flycheck::{FlycheckConfig, FlycheckHandle};
|
||||||
use hir::db::DefDatabase;
|
use hir::{db::DefDatabase, Change, ProcMacros};
|
||||||
use ide::Change;
|
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{salsa::Durability, CrateGraph, ProcMacroPaths, ProcMacros},
|
base_db::{salsa::Durability, CrateGraph, ProcMacroPaths},
|
||||||
FxHashMap,
|
FxHashMap,
|
||||||
};
|
};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
|
|
Loading…
Reference in a new issue