Rename ProcMacroKind::FuncLike to Bang

This commit is contained in:
Lukas Wirth 2024-03-21 09:33:17 +01:00
parent fc0d51ae65
commit 8e324e98a1
18 changed files with 83 additions and 66 deletions

View file

@ -500,13 +500,6 @@ impl CrateGraph {
} }
} }
// FIXME: this only finds one crate with the given root; we could have multiple
pub fn crate_id_for_crate_root(&self, file_id: FileId) -> Option<CrateId> {
let (crate_id, _) =
self.arena.iter().find(|(_crate_id, data)| data.root_file_id == file_id)?;
Some(crate_id)
}
pub fn sort_deps(&mut self) { pub fn sort_deps(&mut self) {
self.arena self.arena
.iter_mut() .iter_mut()

View file

@ -453,8 +453,8 @@ impl ProcMacroData {
( (
def.name, def.name,
match def.kind { match def.kind {
ProcMacroKind::CustomDerive { helpers } => Some(helpers), ProcMacroKind::Derive { helpers } => Some(helpers),
ProcMacroKind::FnLike | ProcMacroKind::Attr => None, ProcMacroKind::Bang | ProcMacroKind::Attr => None,
}, },
) )
} else { } else {
@ -484,10 +484,11 @@ impl ExternCrateDeclData {
let extern_crate = &item_tree[loc.id.value]; let extern_crate = &item_tree[loc.id.value];
let name = extern_crate.name.clone(); let name = extern_crate.name.clone();
let krate = loc.container.krate();
let crate_id = if name == hir_expand::name![self] { let crate_id = if name == hir_expand::name![self] {
Some(loc.container.krate()) Some(krate)
} else { } else {
db.crate_def_map(loc.container.krate()) db.crate_def_map(krate)
.extern_prelude() .extern_prelude()
.find(|&(prelude_name, ..)| *prelude_name == name) .find(|&(prelude_name, ..)| *prelude_name == name)
.map(|(_, (root, _))| root.krate()) .map(|(_, (root, _))| root.krate())

View file

@ -737,7 +737,7 @@ impl MacroSubNs {
MacroId::ProcMacroId(it) => { MacroId::ProcMacroId(it) => {
return match it.lookup(db).kind { return match it.lookup(db).kind {
ProcMacroKind::CustomDerive | ProcMacroKind::Attr => Self::Attr, ProcMacroKind::CustomDerive | ProcMacroKind::Attr => Self::Attr,
ProcMacroKind::FuncLike => Self::Bang, ProcMacroKind::Bang => Self::Bang,
}; };
} }
}; };

View file

@ -604,7 +604,7 @@ impl DefCollector<'_> {
.intern(self.db); .intern(self.db);
self.define_proc_macro(def.name.clone(), proc_macro_id); self.define_proc_macro(def.name.clone(), proc_macro_id);
let crate_data = Arc::get_mut(&mut self.def_map.data).unwrap(); let crate_data = Arc::get_mut(&mut self.def_map.data).unwrap();
if let ProcMacroKind::CustomDerive { helpers } = def.kind { if let ProcMacroKind::Derive { helpers } = def.kind {
crate_data.exported_derives.insert(self.db.macro_def(proc_macro_id.into()), helpers); crate_data.exported_derives.insert(self.db.macro_def(proc_macro_id.into()), helpers);
} }
crate_data.fn_proc_macro_mapping.insert(fn_id, proc_macro_id); crate_data.fn_proc_macro_mapping.insert(fn_id, proc_macro_id);

View file

@ -13,18 +13,16 @@ pub struct ProcMacroDef {
#[derive(Debug, PartialEq, Eq)] #[derive(Debug, PartialEq, Eq)]
pub enum ProcMacroKind { pub enum ProcMacroKind {
CustomDerive { helpers: Box<[Name]> }, Derive { helpers: Box<[Name]> },
FnLike, Bang,
Attr, Attr,
} }
impl ProcMacroKind { impl ProcMacroKind {
pub(super) fn to_basedb_kind(&self) -> hir_expand::proc_macro::ProcMacroKind { pub(super) fn to_basedb_kind(&self) -> hir_expand::proc_macro::ProcMacroKind {
match self { match self {
ProcMacroKind::CustomDerive { .. } => { ProcMacroKind::Derive { .. } => hir_expand::proc_macro::ProcMacroKind::CustomDerive,
hir_expand::proc_macro::ProcMacroKind::CustomDerive ProcMacroKind::Bang => hir_expand::proc_macro::ProcMacroKind::Bang,
}
ProcMacroKind::FnLike => hir_expand::proc_macro::ProcMacroKind::FuncLike,
ProcMacroKind::Attr => hir_expand::proc_macro::ProcMacroKind::Attr, ProcMacroKind::Attr => hir_expand::proc_macro::ProcMacroKind::Attr,
} }
} }
@ -34,13 +32,13 @@ impl Attrs {
#[rustfmt::skip] #[rustfmt::skip]
pub fn parse_proc_macro_decl(&self, func_name: &Name) -> Option<ProcMacroDef> { pub fn parse_proc_macro_decl(&self, func_name: &Name) -> Option<ProcMacroDef> {
if self.is_proc_macro() { if self.is_proc_macro() {
Some(ProcMacroDef { name: func_name.clone(), kind: ProcMacroKind::FnLike }) Some(ProcMacroDef { name: func_name.clone(), kind: ProcMacroKind::Bang })
} else if self.is_proc_macro_attribute() { } else if self.is_proc_macro_attribute() {
Some(ProcMacroDef { name: func_name.clone(), kind: ProcMacroKind::Attr }) Some(ProcMacroDef { name: func_name.clone(), kind: ProcMacroKind::Attr })
} else if self.by_key("proc_macro_derive").exists() { } else if self.by_key("proc_macro_derive").exists() {
let derive = self.by_key("proc_macro_derive").tt_values().next()?; let derive = self.by_key("proc_macro_derive").tt_values().next()?;
let def = parse_macro_name_and_helper_attrs(&derive.token_trees) let def = parse_macro_name_and_helper_attrs(&derive.token_trees)
.map(|(name, helpers)| ProcMacroDef { name, kind: ProcMacroKind::CustomDerive { helpers } }); .map(|(name, helpers)| ProcMacroDef { name, kind: ProcMacroKind::Derive { helpers } });
if def.is_none() { if def.is_none() {
tracing::trace!("malformed `#[proc_macro_derive]`: {}", derive); tracing::trace!("malformed `#[proc_macro_derive]`: {}", derive);

View file

@ -200,7 +200,7 @@ pub struct EagerCallInfo {
/// Call id of the eager macro's input file (this is the macro file for its fully expanded input). /// Call id of the eager macro's input file (this is the macro file for its fully expanded input).
arg_id: MacroCallId, arg_id: MacroCallId,
error: Option<ExpandError>, error: Option<ExpandError>,
/// TODO: Doc /// The call site span of the eager macro
span: Span, span: Span,
} }
@ -211,7 +211,7 @@ pub enum MacroCallKind {
expand_to: ExpandTo, expand_to: ExpandTo,
/// Some if this is a macro call for an eager macro. Note that this is `None` /// Some if this is a macro call for an eager macro. Note that this is `None`
/// for the eager input macro file. /// for the eager input macro file.
// FIXME: This is being interned, subtrees can vary quickly differ just slightly causing // FIXME: This is being interned, subtrees can vary quickly differing just slightly causing
// leakage problems here // leakage problems here
eager: Option<Arc<EagerCallInfo>>, eager: Option<Arc<EagerCallInfo>>,
}, },
@ -486,7 +486,7 @@ impl MacroDefId {
matches!( matches!(
self.kind, self.kind,
MacroDefKind::BuiltIn(..) MacroDefKind::BuiltIn(..)
| MacroDefKind::ProcMacro(_, ProcMacroKind::FuncLike, _) | MacroDefKind::ProcMacro(_, ProcMacroKind::Bang, _)
| MacroDefKind::BuiltInEager(..) | MacroDefKind::BuiltInEager(..)
| MacroDefKind::Declarative(..) | MacroDefKind::Declarative(..)
) )
@ -808,7 +808,8 @@ impl ExpansionInfo {
let (parse, exp_map) = db.parse_macro_expansion(macro_file).value; let (parse, exp_map) = db.parse_macro_expansion(macro_file).value;
let expanded = InMacroFile { file_id: macro_file, value: parse.syntax_node() }; let expanded = InMacroFile { file_id: macro_file, value: parse.syntax_node() };
let (macro_arg, _, _) = db.macro_arg(macro_file.macro_call_id); let (macro_arg, _, _) =
db.macro_arg_considering_derives(macro_file.macro_call_id, &loc.kind);
let def = loc.def.ast_id().left().and_then(|id| { let def = loc.def.ast_id().left().and_then(|id| {
let def_tt = match id.to_node(db) { let def_tt = match id.to_node(db) {

View file

@ -23,7 +23,7 @@ impl ProcMacroId {
#[derive(Copy, Clone, Eq, PartialEq, Debug, Hash)] #[derive(Copy, Clone, Eq, PartialEq, Debug, Hash)]
pub enum ProcMacroKind { pub enum ProcMacroKind {
CustomDerive, CustomDerive,
FuncLike, Bang,
Attr, Attr,
} }

View file

@ -2592,7 +2592,7 @@ impl Macro {
}, },
MacroId::ProcMacroId(it) => match it.lookup(db.upcast()).kind { MacroId::ProcMacroId(it) => match it.lookup(db.upcast()).kind {
ProcMacroKind::CustomDerive => MacroKind::Derive, ProcMacroKind::CustomDerive => MacroKind::Derive,
ProcMacroKind::FuncLike => MacroKind::ProcMacro, ProcMacroKind::Bang => MacroKind::ProcMacro,
ProcMacroKind::Attr => MacroKind::Attr, ProcMacroKind::Attr => MacroKind::Attr,
}, },
} }

View file

@ -48,7 +48,7 @@ pre { color: #DCDCCC; background: #3F3F3F; font-size: 22px; padd
<pre><code><span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="builtin_attr attribute library">allow</span><span class="parenthesis attribute">(</span><span class="none attribute">dead_code</span><span class="parenthesis attribute">)</span><span class="attribute_bracket attribute">]</span> <pre><code><span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="builtin_attr attribute library">allow</span><span class="parenthesis attribute">(</span><span class="none attribute">dead_code</span><span class="parenthesis attribute">)</span><span class="attribute_bracket attribute">]</span>
<span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="tool_module attribute library">rustfmt</span><span class="operator attribute">::</span><span class="tool_module attribute library">skip</span><span class="attribute_bracket attribute">]</span> <span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="tool_module attribute library">rustfmt</span><span class="operator attribute">::</span><span class="tool_module attribute library">skip</span><span class="attribute_bracket attribute">]</span>
<span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="module attribute crate_root library">proc_macros</span><span class="operator attribute">::</span><span class="attribute attribute library">identity</span><span class="attribute_bracket attribute">]</span> <span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="module attribute crate_root library">proc_macros</span><span class="operator attribute">::</span><span class="attribute attribute library">identity</span><span class="attribute_bracket attribute">]</span>
<span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="attribute attribute default_library library">derive</span><span class="parenthesis attribute">(</span><span class="derive attribute default_library library">Copy</span><span class="parenthesis attribute">)</span><span class="attribute_bracket attribute">]</span> <span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="attribute attribute default_library library">derive</span><span class="parenthesis attribute">(</span><span class="derive attribute default_library library">Default</span><span class="parenthesis attribute">)</span><span class="attribute_bracket attribute">]</span>
<span class="comment documentation">/// This is a doc comment</span> <span class="comment documentation">/// This is a doc comment</span>
<span class="comment">// This is a normal comment</span> <span class="comment">// This is a normal comment</span>
<span class="comment documentation">/// This is a doc comment</span> <span class="comment documentation">/// This is a doc comment</span>
@ -58,4 +58,7 @@ pre { color: #DCDCCC; background: #3F3F3F; font-size: 22px; padd
<span class="comment">// This is another normal comment</span> <span class="comment">// This is another normal comment</span>
<span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="attribute attribute default_library library">derive</span><span class="parenthesis attribute">(</span><span class="derive attribute default_library library">Copy</span><span class="comma attribute">,</span> <span class="unresolved_reference attribute">Unresolved</span><span class="parenthesis attribute">)</span><span class="attribute_bracket attribute">]</span> <span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="attribute attribute default_library library">derive</span><span class="parenthesis attribute">(</span><span class="derive attribute default_library library">Copy</span><span class="comma attribute">,</span> <span class="unresolved_reference attribute">Unresolved</span><span class="parenthesis attribute">)</span><span class="attribute_bracket attribute">]</span>
<span class="comment">// The reason for these being here is to test AttrIds</span> <span class="comment">// The reason for these being here is to test AttrIds</span>
<span class="keyword">struct</span> <span class="struct declaration">Foo</span><span class="semicolon">;</span></code></pre> <span class="keyword">enum</span> <span class="enum declaration">Foo</span> <span class="brace">{</span>
<span class="attribute_bracket attribute">#</span><span class="attribute_bracket attribute">[</span><span class="derive_helper attribute default_library library">default</span><span class="attribute_bracket attribute">]</span>
<span class="enum_variant declaration">Bar</span>
<span class="brace">}</span></code></pre>

View file

@ -22,11 +22,11 @@ fn attributes() {
check_highlighting( check_highlighting(
r#" r#"
//- proc_macros: identity //- proc_macros: identity
//- minicore: derive, copy //- minicore: derive, copy, default
#[allow(dead_code)] #[allow(dead_code)]
#[rustfmt::skip] #[rustfmt::skip]
#[proc_macros::identity] #[proc_macros::identity]
#[derive(Copy)] #[derive(Default)]
/// This is a doc comment /// This is a doc comment
// This is a normal comment // This is a normal comment
/// This is a doc comment /// This is a doc comment
@ -36,7 +36,10 @@ fn attributes() {
// This is another normal comment // This is another normal comment
#[derive(Copy, Unresolved)] #[derive(Copy, Unresolved)]
// The reason for these being here is to test AttrIds // The reason for these being here is to test AttrIds
struct Foo; enum Foo {
#[default]
Bar
}
"#, "#,
expect_file!["./test_data/highlight_attributes.html"], expect_file!["./test_data/highlight_attributes.html"],
false, false,

View file

@ -387,7 +387,7 @@ fn expander_to_proc_macro(
let name = From::from(expander.name()); let name = From::from(expander.name());
let kind = match expander.kind() { let kind = match expander.kind() {
proc_macro_api::ProcMacroKind::CustomDerive => ProcMacroKind::CustomDerive, proc_macro_api::ProcMacroKind::CustomDerive => ProcMacroKind::CustomDerive,
proc_macro_api::ProcMacroKind::FuncLike => ProcMacroKind::FuncLike, proc_macro_api::ProcMacroKind::Bang => ProcMacroKind::Bang,
proc_macro_api::ProcMacroKind::Attr => ProcMacroKind::Attr, proc_macro_api::ProcMacroKind::Attr => ProcMacroKind::Attr,
}; };
let disabled = ignored_macros.iter().any(|replace| **replace == name); let disabled = ignored_macros.iter().any(|replace| **replace == name);

View file

@ -35,8 +35,11 @@ pub use version::{read_dylib_info, read_version, RustCInfo};
#[derive(Copy, Clone, Eq, PartialEq, Debug, Serialize, Deserialize)] #[derive(Copy, Clone, Eq, PartialEq, Debug, Serialize, Deserialize)]
pub enum ProcMacroKind { pub enum ProcMacroKind {
CustomDerive, CustomDerive,
FuncLike,
Attr, Attr,
// This used to be called FuncLike, so that's what the server expects currently.
#[serde(alias = "bang")]
#[serde(rename(serialize = "func_like", deserialize = "func_like"))]
Bang,
} }
/// A handle to an external process which load dylibs with macros (.so or .dll) /// A handle to an external process which load dylibs with macros (.so or .dll)

View file

@ -108,7 +108,7 @@ impl ProcMacros {
(trait_name.to_string(), ProcMacroKind::CustomDerive) (trait_name.to_string(), ProcMacroKind::CustomDerive)
} }
bridge::client::ProcMacro::Bang { name, .. } => { bridge::client::ProcMacro::Bang { name, .. } => {
(name.to_string(), ProcMacroKind::FuncLike) (name.to_string(), ProcMacroKind::Bang)
} }
bridge::client::ProcMacro::Attr { name, .. } => { bridge::client::ProcMacro::Attr { name, .. } => {
(name.to_string(), ProcMacroKind::Attr) (name.to_string(), ProcMacroKind::Attr)

View file

@ -254,14 +254,14 @@ fn list_test_macros() {
let res = list().join("\n"); let res = list().join("\n");
expect![[r#" expect![[r#"
fn_like_noop [FuncLike] fn_like_noop [Bang]
fn_like_panic [FuncLike] fn_like_panic [Bang]
fn_like_error [FuncLike] fn_like_error [Bang]
fn_like_clone_tokens [FuncLike] fn_like_clone_tokens [Bang]
fn_like_mk_literals [FuncLike] fn_like_mk_literals [Bang]
fn_like_mk_idents [FuncLike] fn_like_mk_idents [Bang]
fn_like_span_join [FuncLike] fn_like_span_join [Bang]
fn_like_span_ops [FuncLike] fn_like_span_ops [Bang]
attr_noop [Attr] attr_noop [Attr]
attr_panic [Attr] attr_panic [Attr]
attr_error [Attr] attr_error [Attr]

View file

@ -719,20 +719,23 @@ impl ProjectWorkspace {
) -> (CrateGraph, ProcMacroPaths) { ) -> (CrateGraph, ProcMacroPaths) {
let _p = tracing::span!(tracing::Level::INFO, "ProjectWorkspace::to_crate_graph").entered(); let _p = tracing::span!(tracing::Level::INFO, "ProjectWorkspace::to_crate_graph").entered();
let (mut crate_graph, proc_macros) = match self { let ((mut crate_graph, proc_macros), sysroot) = match self {
ProjectWorkspace::Json { ProjectWorkspace::Json {
project, project,
sysroot, sysroot,
rustc_cfg, rustc_cfg,
toolchain: _, toolchain: _,
target_layout: _, target_layout: _,
} => project_json_to_crate_graph( } => (
project_json_to_crate_graph(
rustc_cfg.clone(), rustc_cfg.clone(),
load, load,
project, project,
sysroot.as_ref().ok(), sysroot.as_ref().ok(),
extra_env, extra_env,
), ),
sysroot,
),
ProjectWorkspace::Cargo { ProjectWorkspace::Cargo {
cargo, cargo,
sysroot, sysroot,
@ -743,7 +746,8 @@ impl ProjectWorkspace {
toolchain: _, toolchain: _,
target_layout: _, target_layout: _,
cargo_config_extra_env: _, cargo_config_extra_env: _,
} => cargo_to_crate_graph( } => (
cargo_to_crate_graph(
load, load,
rustc.as_ref().map(|a| a.as_ref()).ok(), rustc.as_ref().map(|a| a.as_ref()).ok(),
cargo, cargo,
@ -752,17 +756,28 @@ impl ProjectWorkspace {
cfg_overrides, cfg_overrides,
build_scripts, build_scripts,
), ),
sysroot,
),
ProjectWorkspace::DetachedFiles { ProjectWorkspace::DetachedFiles {
files, files,
sysroot, sysroot,
rustc_cfg, rustc_cfg,
toolchain: _, toolchain: _,
target_layout: _, target_layout: _,
} => { } => (
detached_files_to_crate_graph(rustc_cfg.clone(), load, files, sysroot.as_ref().ok()) detached_files_to_crate_graph(
} rustc_cfg.clone(),
load,
files,
sysroot.as_ref().ok(),
),
sysroot,
),
}; };
if crate_graph.patch_cfg_if() {
if matches!(sysroot.as_ref().map(|it| it.mode()), Ok(SysrootMode::Workspace(_)))
&& crate_graph.patch_cfg_if()
{
tracing::debug!("Patched std to depend on cfg-if") tracing::debug!("Patched std to depend on cfg-if")
} else { } else {
tracing::debug!("Did not patch std to depend on cfg-if") tracing::debug!("Did not patch std to depend on cfg-if")

View file

@ -26,7 +26,6 @@ use itertools::Itertools;
use load_cargo::{load_proc_macro, ProjectFolders}; use load_cargo::{load_proc_macro, ProjectFolders};
use proc_macro_api::ProcMacroServer; use proc_macro_api::ProcMacroServer;
use project_model::{ProjectWorkspace, WorkspaceBuildScripts}; use project_model::{ProjectWorkspace, WorkspaceBuildScripts};
use rustc_hash::FxHashSet;
use stdx::{format_to, thread::ThreadIntent}; use stdx::{format_to, thread::ThreadIntent};
use triomphe::Arc; use triomphe::Arc;
use vfs::{AbsPath, AbsPathBuf, ChangeKind}; use vfs::{AbsPath, AbsPathBuf, ChangeKind};
@ -526,7 +525,7 @@ impl GlobalState {
fn recreate_crate_graph(&mut self, cause: String) { fn recreate_crate_graph(&mut self, cause: String) {
// crate graph construction relies on these paths, record them so when one of them gets // crate graph construction relies on these paths, record them so when one of them gets
// deleted or created we trigger a reconstruction of the crate graph // deleted or created we trigger a reconstruction of the crate graph
let mut crate_graph_file_dependencies = FxHashSet::default(); let mut crate_graph_file_dependencies = mem::take(&mut self.crate_graph_file_dependencies);
self.report_progress( self.report_progress(
"Building CrateGraph", "Building CrateGraph",
crate::lsp::utils::Progress::Begin, crate::lsp::utils::Progress::Begin,

View file

@ -903,6 +903,7 @@ fn out_dirs_check() {
} }
#[test] #[test]
#[cfg(not(windows))] // windows requires elevated permissions to create symlinks
fn root_contains_symlink_out_dirs_check() { fn root_contains_symlink_out_dirs_check() {
out_dirs_check_impl(true); out_dirs_check_impl(true);
} }

View file

@ -402,7 +402,7 @@ pub fn mirror(input: TokenStream) -> TokenStream {
.into(), .into(),
ProcMacro { ProcMacro {
name: "mirror".into(), name: "mirror".into(),
kind: ProcMacroKind::FuncLike, kind: ProcMacroKind::Bang,
expander: sync::Arc::new(MirrorProcMacroExpander), expander: sync::Arc::new(MirrorProcMacroExpander),
disabled: false, disabled: false,
}, },
@ -417,7 +417,7 @@ pub fn shorten(input: TokenStream) -> TokenStream {
.into(), .into(),
ProcMacro { ProcMacro {
name: "shorten".into(), name: "shorten".into(),
kind: ProcMacroKind::FuncLike, kind: ProcMacroKind::Bang,
expander: sync::Arc::new(ShortenProcMacroExpander), expander: sync::Arc::new(ShortenProcMacroExpander),
disabled: false, disabled: false,
}, },