Auto merge of #14468 - lowr:patch/expand-macro-bang, r=Veykril

Expand Macro Recursively: don't append "!" to non-bang macro name

When we run `Expand Macro Recursively`, we prepend a comment "Recursive expansion of foo! macro" to the expansion result. I've noticed we unconditionally render the macro name with "!" and, while super subtle, I feel a bit awkward when the macro is either a derive or attribute macro.
This commit is contained in:
bors 2023-04-02 11:36:47 +00:00
commit 236576227a
2 changed files with 23 additions and 21 deletions

View file

@ -83,8 +83,10 @@ pub(crate) fn expand_macro(db: &RootDatabase, position: FilePosition) -> Option<
} }
} }
if let Some(mac) = ast::MacroCall::cast(node) { if let Some(mac) = ast::MacroCall::cast(node) {
let mut name = mac.path()?.segment()?.name_ref()?.to_string();
name.push('!');
break ( break (
mac.path()?.segment()?.name_ref()?.to_string(), name,
expand_macro_recur(&sema, &mac)?, expand_macro_recur(&sema, &mac)?,
mac.syntax().parent().map(|it| it.kind()).unwrap_or(SyntaxKind::MACRO_ITEMS), mac.syntax().parent().map(|it| it.kind()).unwrap_or(SyntaxKind::MACRO_ITEMS),
); );
@ -235,7 +237,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
bar bar!
5i64 as _"#]], 5i64 as _"#]],
); );
} }
@ -252,7 +254,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
bar bar!
for _ in 0..42{}"#]], for _ in 0..42{}"#]],
); );
} }
@ -273,7 +275,7 @@ macro_rules! baz {
f$0oo!(); f$0oo!();
"#, "#,
expect![[r#" expect![[r#"
foo foo!
fn b(){} fn b(){}
"#]], "#]],
); );
@ -294,7 +296,7 @@ macro_rules! foo {
f$0oo!(); f$0oo!();
"#, "#,
expect![[r#" expect![[r#"
foo foo!
fn some_thing() -> u32 { fn some_thing() -> u32 {
let a = 0; let a = 0;
a+10 a+10
@ -328,7 +330,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
match_ast match_ast!
{ {
if let Some(it) = ast::TraitDef::cast(container.clone()){} if let Some(it) = ast::TraitDef::cast(container.clone()){}
else if let Some(it) = ast::ImplDef::cast(container.clone()){} else if let Some(it) = ast::ImplDef::cast(container.clone()){}
@ -358,7 +360,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
match_ast match_ast!
{}"#]], {}"#]],
); );
} }
@ -383,7 +385,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
foo foo!
{ {
macro_rules! bar { macro_rules! bar {
() => { () => {
@ -411,7 +413,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
foo foo!
"#]], "#]],
); );
} }
@ -433,7 +435,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
foo foo!
0"#]], 0"#]],
); );
} }
@ -451,7 +453,7 @@ fn main() {
} }
"#, "#,
expect![[r#" expect![[r#"
foo foo!
fn f<T>(_: &dyn ::std::marker::Copy){}"#]], fn f<T>(_: &dyn ::std::marker::Copy){}"#]],
); );
} }

View file

@ -699,7 +699,7 @@ export function viewFullCrateGraph(ctx: CtxInit): Cmd {
// The contents of the file come from the `TextDocumentContentProvider` // The contents of the file come from the `TextDocumentContentProvider`
export function expandMacro(ctx: CtxInit): Cmd { export function expandMacro(ctx: CtxInit): Cmd {
function codeFormat(expanded: ra.ExpandedMacro): string { function codeFormat(expanded: ra.ExpandedMacro): string {
let result = `// Recursive expansion of ${expanded.name}! macro\n`; let result = `// Recursive expansion of ${expanded.name} macro\n`;
result += "// " + "=".repeat(result.length - 3); result += "// " + "=".repeat(result.length - 3);
result += "\n\n"; result += "\n\n";
result += expanded.expansion; result += expanded.expansion;