Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/ide-assists/src/handlers/inline_macro.rs')
-rw-r--r--crates/ide-assists/src/handlers/inline_macro.rs21
1 files changed, 6 insertions, 15 deletions
diff --git a/crates/ide-assists/src/handlers/inline_macro.rs b/crates/ide-assists/src/handlers/inline_macro.rs
index d669826aa7..9d03f03d20 100644
--- a/crates/ide-assists/src/handlers/inline_macro.rs
+++ b/crates/ide-assists/src/handlers/inline_macro.rs
@@ -34,25 +34,16 @@ use crate::{AssistContext, AssistId, AssistKind, Assists};
// }
// ```
pub(crate) fn inline_macro(acc: &mut Assists, ctx: &AssistContext<'_>) -> Option<()> {
- let tok = ctx.token_at_offset().right_biased()?;
-
- let mut anc = tok.parent_ancestors();
- let (_name, expanded, unexpanded) = loop {
- let node = anc.next()?;
- if let Some(mac) = ast::MacroCall::cast(node.clone()) {
- break (
- mac.path()?.segment()?.name_ref()?.to_string(),
- ctx.sema.expand(&mac)?.clone_for_update(),
- node,
- );
- }
- };
+ let unexpanded = ctx.find_node_at_offset::<ast::MacroCall>()?;
+ let expanded = ctx.sema.expand(&unexpanded)?.clone_for_update();
+
+ let text_range = unexpanded.syntax().text_range();
acc.add(
AssistId("inline_macro", AssistKind::RefactorRewrite),
format!("Inline macro"),
- unexpanded.text_range(),
- |builder| builder.replace(unexpanded.text_range(), expanded.to_string()),
+ text_range,
+ |builder| builder.replace(text_range, expanded.to_string()),
)
}