mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-26 13:03:31 +00:00
Fix bug when $crate in LHS in mbe
This commit is contained in:
parent
1a29934c37
commit
74a24adc8e
2 changed files with 8 additions and 5 deletions
|
@ -119,11 +119,10 @@ fn expand_subtree(
|
|||
}
|
||||
|
||||
fn expand_var(ctx: &mut ExpandCtx, v: &SmolStr, id: tt::TokenId) -> ExpandResult<Fragment> {
|
||||
if v == "crate" {
|
||||
// We simply produce identifier `$crate` here. And it will be resolved when lowering ast to Path.
|
||||
let tt = tt::Leaf::from(tt::Ident { text: "$crate".into(), id }).into();
|
||||
ExpandResult::ok(Fragment::Tokens(tt))
|
||||
} else if !ctx.bindings.contains(v) {
|
||||
// We already handle $crate case in mbe parser
|
||||
debug_assert!(v != "crate");
|
||||
|
||||
if !ctx.bindings.contains(v) {
|
||||
// Note that it is possible to have a `$var` inside a macro which is not bound.
|
||||
// For example:
|
||||
// ```
|
||||
|
|
|
@ -109,6 +109,10 @@ fn next_op<'a>(first: &tt::TokenTree, src: &mut TtIter<'a>, mode: Mode) -> Resul
|
|||
let id = punct.id;
|
||||
Op::Var { name, kind, id }
|
||||
}
|
||||
tt::Leaf::Ident(ident) if ident.text == "crate" => {
|
||||
// We simply produce identifier `$crate` here. And it will be resolved when lowering ast to Path.
|
||||
Op::Leaf(tt::Leaf::from(tt::Ident { text: "$crate".into(), id: ident.id }))
|
||||
}
|
||||
tt::Leaf::Ident(ident) => {
|
||||
let name = ident.text.clone();
|
||||
let kind = eat_fragment_kind(src, mode)?;
|
||||
|
|
Loading…
Reference in a new issue