Skip to content

Commit bbd5dd0

Browse files
Merge #10412
10412: feat: highlight `asm!` as format string r=jonas-schievink a=jonas-schievink ![screenshot-2021-10-01-12:34:31](https://user-images.githubusercontent.com/1786438/135606261-a1cb6caf-0a7f-45f7-9dde-0275370b0889.png) part of #10394 bors r+ Co-authored-by: Jonas Schievink <[email protected]>
2 parents 8b45de5 + cca6ee5 commit bbd5dd0

File tree

3 files changed

+28
-5
lines changed

3 files changed

+28
-5
lines changed

crates/hir_expand/src/builtin_macro.rs

Lines changed: 22 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -267,13 +267,30 @@ fn format_args_expand(
267267
fn asm_expand(
268268
_db: &dyn AstDatabase,
269269
_id: MacroCallId,
270-
_tt: &tt::Subtree,
270+
tt: &tt::Subtree,
271271
) -> ExpandResult<tt::Subtree> {
272-
// both asm and llvm_asm don't return anything, so we can expand them to nothing,
273-
// for now
274-
let expanded = quote! {
272+
// We expand all assembly snippets to `format_args!` invocations to get format syntax
273+
// highlighting for them.
274+
275+
let krate = tt::Ident { text: "$crate".into(), id: tt::TokenId::unspecified() };
276+
277+
let mut literals = Vec::new();
278+
for tt in tt.token_trees.chunks(2) {
279+
match tt {
280+
[tt::TokenTree::Leaf(tt::Leaf::Literal(lit))]
281+
| [tt::TokenTree::Leaf(tt::Leaf::Literal(lit)), tt::TokenTree::Leaf(tt::Leaf::Punct(tt::Punct { char: ',', id: _, spacing: _ }))] =>
282+
{
283+
let krate = krate.clone();
284+
literals.push(quote!(#krate::format_args!(#lit);));
285+
}
286+
_ => break,
287+
}
288+
}
289+
290+
let expanded = quote! {{
291+
##literals
275292
()
276-
};
293+
}};
277294
ExpandResult::ok(expanded)
278295
}
279296

crates/ide/src/syntax_highlighting/test_data/highlight_strings.html

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -82,6 +82,8 @@
8282
<span class="keyword">macro_rules</span><span class="punctuation">!</span> <span class="macro declaration">panic</span> <span class="brace">{</span><span class="brace">}</span>
8383
<span class="attribute attribute">#</span><span class="attribute attribute">[</span><span class="builtin_attr attribute">rustc_builtin_macro</span><span class="attribute attribute">]</span>
8484
<span class="keyword">macro_rules</span><span class="punctuation">!</span> <span class="macro declaration">assert</span> <span class="brace">{</span><span class="brace">}</span>
85+
<span class="attribute attribute">#</span><span class="attribute attribute">[</span><span class="builtin_attr attribute">rustc_builtin_macro</span><span class="attribute attribute">]</span>
86+
<span class="keyword">macro_rules</span><span class="punctuation">!</span> <span class="macro declaration">asm</span> <span class="brace">{</span><span class="brace">}</span>
8587

8688
<span class="keyword">macro_rules</span><span class="punctuation">!</span> <span class="macro declaration">toho</span> <span class="brace">{</span>
8789
<span class="parenthesis">(</span><span class="parenthesis">)</span> <span class="operator">=</span><span class="angle">&gt;</span> <span class="parenthesis">(</span><span class="punctuation">$</span>crate<span class="colon">:</span><span class="colon">:</span>panic<span class="punctuation">!</span><span class="parenthesis">(</span><span class="string_literal">"not yet implemented"</span><span class="parenthesis">)</span><span class="parenthesis">)</span><span class="semicolon">;</span>
@@ -142,4 +144,5 @@
142144
<span class="macro">assert!</span><span class="parenthesis">(</span><span class="bool_literal">true</span><span class="comma">,</span> <span class="string_literal">"</span><span class="format_specifier">{</span><span class="format_specifier">}</span><span class="string_literal">"</span><span class="comma">,</span> <span class="numeric_literal">1</span><span class="parenthesis">)</span><span class="semicolon">;</span>
143145
<span class="macro">assert!</span><span class="parenthesis">(</span><span class="bool_literal">true</span><span class="comma">,</span> <span class="string_literal">"</span><span class="format_specifier">{</span><span class="format_specifier">}</span><span class="string_literal"> asdasd"</span><span class="comma">,</span> <span class="numeric_literal">1</span><span class="parenthesis">)</span><span class="semicolon">;</span>
144146
<span class="macro">toho!</span><span class="parenthesis">(</span><span class="string_literal">"</span><span class="format_specifier">{</span><span class="format_specifier">}</span><span class="string_literal">fmt"</span><span class="comma">,</span> <span class="numeric_literal">0</span><span class="parenthesis">)</span><span class="semicolon">;</span>
147+
<span class="macro">asm!</span><span class="parenthesis">(</span><span class="string_literal">"mov eax, </span><span class="format_specifier">{</span><span class="numeric_literal">0</span><span class="format_specifier">}</span><span class="string_literal">"</span><span class="parenthesis">)</span><span class="semicolon">;</span>
145148
<span class="brace">}</span></code></pre>

crates/ide/src/syntax_highlighting/tests.rs

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -477,6 +477,8 @@ mod panic {
477477
macro_rules! panic {}
478478
#[rustc_builtin_macro]
479479
macro_rules! assert {}
480+
#[rustc_builtin_macro]
481+
macro_rules! asm {}
480482
481483
macro_rules! toho {
482484
() => ($crate::panic!("not yet implemented"));
@@ -537,6 +539,7 @@ fn main() {
537539
assert!(true, "{}", 1);
538540
assert!(true, "{} asdasd", 1);
539541
toho!("{}fmt", 0);
542+
asm!("mov eax, {0}");
540543
}"#
541544
.trim(),
542545
expect_file!["./test_data/highlight_strings.html"],

0 commit comments

Comments
 (0)