2025-02-26 00:57:27 +08:00
|
|
|
([(line_comment !doc) (block_comment !doc)] @injection.content
|
2021-12-19 22:56:56 +08:00
|
|
|
(#set! injection.language "comment"))
|
|
|
|
|
2025-02-26 00:57:27 +08:00
|
|
|
((doc_comment) @injection.content
|
|
|
|
(#set! injection.language "markdown-rustdoc")
|
|
|
|
(#set! injection.combined))
|
|
|
|
|
2023-10-26 10:39:22 +08:00
|
|
|
((macro_invocation
|
2024-02-08 02:36:29 +08:00
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
2023-10-26 10:39:22 +08:00
|
|
|
(token_tree) @injection.content)
|
2024-02-08 02:36:29 +08:00
|
|
|
(#eq? @_macro_name "html")
|
2023-10-26 10:39:22 +08:00
|
|
|
(#set! injection.language "html")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
2024-02-08 02:36:29 +08:00
|
|
|
((macro_invocation
|
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
|
|
|
(token_tree) @injection.content)
|
|
|
|
(#eq? @_macro_name "slint")
|
|
|
|
(#set! injection.language "slint")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
2021-04-08 22:18:25 +08:00
|
|
|
((macro_invocation
|
|
|
|
(token_tree) @injection.content)
|
|
|
|
(#set! injection.language "rust")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
|
|
|
((macro_rule
|
|
|
|
(token_tree) @injection.content)
|
|
|
|
(#set! injection.language "rust")
|
|
|
|
(#set! injection.include-children))
|
2022-01-06 23:00:00 +08:00
|
|
|
|
2025-03-13 05:40:08 +08:00
|
|
|
((macro_invocation
|
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
|
|
|
(token_tree
|
|
|
|
(token_tree . "{" "}" .) @injection.content))
|
|
|
|
(#eq? @_macro_name "json")
|
|
|
|
(#set! injection.language "json")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
2022-01-06 23:00:00 +08:00
|
|
|
(call_expression
|
|
|
|
function: (scoped_identifier
|
2025-03-13 05:31:05 +08:00
|
|
|
path: (identifier) @_regex (#any-of? @_regex "Regex" "RegexBuilder")
|
2022-01-06 23:00:00 +08:00
|
|
|
name: (identifier) @_new (#eq? @_new "new"))
|
2025-03-13 05:31:05 +08:00
|
|
|
arguments: (arguments (raw_string_literal (string_content) @injection.content))
|
2022-01-06 23:00:00 +08:00
|
|
|
(#set! injection.language "regex"))
|
|
|
|
|
|
|
|
(call_expression
|
|
|
|
function: (scoped_identifier
|
2025-03-13 05:31:05 +08:00
|
|
|
path: (scoped_identifier (identifier) @_regex (#any-of? @_regex "Regex" "RegexBuilder") .)
|
2022-01-06 23:00:00 +08:00
|
|
|
name: (identifier) @_new (#eq? @_new "new"))
|
2025-03-13 05:31:05 +08:00
|
|
|
arguments: (arguments (raw_string_literal (string_content) @injection.content))
|
2022-01-06 23:00:00 +08:00
|
|
|
(#set! injection.language "regex"))
|
2022-09-03 06:26:42 +08:00
|
|
|
|
2023-04-27 13:37:17 +08:00
|
|
|
; Highlight SQL in `sqlx::query!()`, `sqlx::query_scalar!()`, and `sqlx::query_scalar_unchecked!()`
|
2022-09-03 06:26:42 +08:00
|
|
|
(macro_invocation
|
|
|
|
macro: (scoped_identifier
|
|
|
|
path: (identifier) @_sqlx (#eq? @_sqlx "sqlx")
|
2023-04-27 13:37:17 +08:00
|
|
|
name: (identifier) @_query (#match? @_query "^query(_scalar|_scalar_unchecked)?$"))
|
2022-09-03 06:26:42 +08:00
|
|
|
(token_tree
|
|
|
|
; Only the first argument is SQL
|
|
|
|
.
|
2025-03-13 05:31:05 +08:00
|
|
|
[
|
|
|
|
(string_literal (string_content) @injection.content)
|
|
|
|
(raw_string_literal (string_content) @injection.content)
|
|
|
|
]
|
2022-09-03 06:26:42 +08:00
|
|
|
)
|
|
|
|
(#set! injection.language "sql"))
|
|
|
|
|
2023-04-27 13:37:17 +08:00
|
|
|
; Highlight SQL in `sqlx::query_as!()` and `sqlx::query_as_unchecked!()`
|
2022-09-03 06:26:42 +08:00
|
|
|
(macro_invocation
|
|
|
|
macro: (scoped_identifier
|
|
|
|
path: (identifier) @_sqlx (#eq? @_sqlx "sqlx")
|
2023-04-27 13:37:17 +08:00
|
|
|
name: (identifier) @_query_as (#match? @_query_as "^query_as(_unchecked)?$"))
|
2023-03-11 06:57:52 +08:00
|
|
|
(token_tree
|
|
|
|
; Only the second argument is SQL
|
|
|
|
.
|
|
|
|
; Allow anything as the first argument in case the user has lower case type
|
|
|
|
; names for some reason
|
|
|
|
(_)
|
2025-03-13 05:31:05 +08:00
|
|
|
[
|
|
|
|
(string_literal (string_content) @injection.content)
|
|
|
|
(raw_string_literal (string_content) @injection.content)
|
|
|
|
]
|
2023-03-11 06:57:52 +08:00
|
|
|
)
|
|
|
|
(#set! injection.language "sql"))
|
2025-02-04 11:31:04 +08:00
|
|
|
|
|
|
|
; std::fmt
|
|
|
|
|
|
|
|
; For these, only the first argument is format_args!
|
|
|
|
((macro_invocation
|
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
|
|
|
(token_tree . (string_literal) @injection.content))
|
|
|
|
(#any-of? @_macro_name
|
|
|
|
; std
|
|
|
|
"format"
|
|
|
|
"print"
|
|
|
|
"println"
|
|
|
|
"eprint"
|
|
|
|
"eprintln"
|
|
|
|
"format_args"
|
|
|
|
"todo"
|
|
|
|
"unreachable"
|
|
|
|
"unimplemented"
|
|
|
|
"compile_error"
|
|
|
|
; log
|
|
|
|
"crit"
|
|
|
|
"trace"
|
|
|
|
"debug"
|
|
|
|
"info"
|
|
|
|
"warn"
|
|
|
|
"error"
|
|
|
|
; anyhow
|
|
|
|
"anyhow"
|
|
|
|
"bail"
|
|
|
|
; syn
|
|
|
|
"format_ident"
|
|
|
|
; indoc
|
|
|
|
"formatdoc"
|
|
|
|
"printdoc"
|
|
|
|
"eprintdoc"
|
|
|
|
"writedoc")
|
|
|
|
(#set! injection.language "rustfmt")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
|
|
|
; For these, only the second argument is format_args!
|
|
|
|
((macro_invocation
|
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
|
|
|
(token_tree . (_) . (string_literal) @injection.content))
|
|
|
|
(#any-of? @_macro_name
|
|
|
|
; std
|
|
|
|
"write"
|
|
|
|
"writeln"
|
|
|
|
"assert"
|
|
|
|
"debug_assert")
|
|
|
|
(#set! injection.language "rustfmt")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
|
|
|
; For these, only the third argument is format_args!
|
|
|
|
((macro_invocation
|
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
|
|
|
(token_tree . (_) . (_) . (string_literal) @injection.content))
|
|
|
|
(#any-of? @_macro_name
|
|
|
|
; std
|
|
|
|
"assert_eq"
|
|
|
|
"debug_assert_eq"
|
|
|
|
"assert_ne"
|
|
|
|
"debug_assert_ne")
|
|
|
|
(#set! injection.language "rustfmt")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
|
|
|
; Dioxus' "rsx!" macro relies heavily on string interpolation as well. The strings can be nested very deeply
|
|
|
|
((macro_invocation
|
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
|
|
|
; TODO: This only captures 1 level of string literals. But in dioxus you can have
|
|
|
|
; nested string literals. For instance:
|
|
|
|
;
|
|
|
|
; rsx! { "{hello} world" }:
|
|
|
|
; -> (token_tree (string_literal))
|
|
|
|
; rsx! { div { "{hello} world" } }
|
|
|
|
; -> (token_tree (token_tree (string_literal)))
|
|
|
|
; rsx! { div { div { "{hello} world" } } }
|
|
|
|
; -> (token_tree (token_tree (token_tree (string_literal))))
|
|
|
|
(token_tree (string_literal) @injection.content))
|
|
|
|
(#eq? @_macro_name "rsx")
|
|
|
|
(#set! injection.language "rustfmt")
|
|
|
|
(#set! injection.include-children))
|