mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 06:03:58 +00:00
fix: Remove another faulty unwrap (expect)
This commit is contained in:
parent
7c765d9f9e
commit
bf5624664d
1 changed files with 22 additions and 20 deletions
|
@ -79,33 +79,35 @@ pub fn expand_eager_macro_input(
|
||||||
return Ok(ExpandResult { value: None, err });
|
return Ok(ExpandResult { value: None, err });
|
||||||
};
|
};
|
||||||
|
|
||||||
let og_tmap = mbe::syntax_node_to_token_map(
|
|
||||||
macro_call.value.token_tree().expect("macro_arg_text succeeded").syntax(),
|
|
||||||
);
|
|
||||||
|
|
||||||
let (mut subtree, expanded_eager_input_token_map) =
|
let (mut subtree, expanded_eager_input_token_map) =
|
||||||
mbe::syntax_node_to_token_tree(&expanded_eager_input);
|
mbe::syntax_node_to_token_tree(&expanded_eager_input);
|
||||||
|
|
||||||
// The tokenmap and ids of subtree point into the expanded syntax node, but that is inaccessible from the outside
|
let og_tmap = if let Some(tt) = macro_call.value.token_tree() {
|
||||||
// so we need to remap them to the original input of the eager macro.
|
let og_tmap = mbe::syntax_node_to_token_map(tt.syntax());
|
||||||
subtree.visit_ids(&|id| {
|
// The tokenmap and ids of subtree point into the expanded syntax node, but that is inaccessible from the outside
|
||||||
// Note: we discard all token ids of braces and the like here, but that's not too bad and only a temporary fix
|
// so we need to remap them to the original input of the eager macro.
|
||||||
|
subtree.visit_ids(&|id| {
|
||||||
|
// Note: we discard all token ids of braces and the like here, but that's not too bad and only a temporary fix
|
||||||
|
|
||||||
if let Some(range) =
|
if let Some(range) = expanded_eager_input_token_map
|
||||||
expanded_eager_input_token_map.first_range_by_token(id, syntax::SyntaxKind::TOMBSTONE)
|
.first_range_by_token(id, syntax::SyntaxKind::TOMBSTONE)
|
||||||
{
|
{
|
||||||
// remap from expanded eager input to eager input expansion
|
// remap from expanded eager input to eager input expansion
|
||||||
if let Some(og_range) = mapping.get(&range) {
|
if let Some(og_range) = mapping.get(&range) {
|
||||||
// remap from eager input expansion to original eager input
|
// remap from eager input expansion to original eager input
|
||||||
if let Some(&og_range) = ws_mapping.get(og_range) {
|
if let Some(&og_range) = ws_mapping.get(og_range) {
|
||||||
if let Some(og_token) = og_tmap.token_by_range(og_range) {
|
if let Some(og_token) = og_tmap.token_by_range(og_range) {
|
||||||
return og_token;
|
return og_token;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
tt::TokenId::UNSPECIFIED
|
||||||
tt::TokenId::UNSPECIFIED
|
});
|
||||||
});
|
og_tmap
|
||||||
|
} else {
|
||||||
|
Default::default()
|
||||||
|
};
|
||||||
subtree.delimiter = crate::tt::Delimiter::unspecified();
|
subtree.delimiter = crate::tt::Delimiter::unspecified();
|
||||||
|
|
||||||
let loc = MacroCallLoc {
|
let loc = MacroCallLoc {
|
||||||
|
|
Loading…
Reference in a new issue