2021-12-19 15:56:56 +01:00
|
|
|
([(line_comment) (block_comment)] @injection.content
|
|
|
|
(#set! injection.language "comment"))
|
|
|
|
|
2023-10-26 04:39:22 +02:00
|
|
|
((macro_invocation
|
2024-02-07 19:36:29 +01:00
|
|
|
macro:
|
|
|
|
[
|
|
|
|
(scoped_identifier
|
|
|
|
name: (_) @_macro_name)
|
|
|
|
(identifier) @_macro_name
|
|
|
|
]
|
2023-10-26 04:39:22 +02:00
|
|
|
(token_tree) @injection.content)
|
2024-02-07 19:36:29 +01:00
|
|
|
(#eq? @_macro_name "html")
|
2023-10-26 04:39:22 +02:00
|
|
|
(#set! injection.language "html")
|
|
|
|
(#set! injection.include-children))
|
|
|
|
|
2024-02-07 19:36:29 +01: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 16:18:25 +02: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 16:00:00 +01:00
|
|
|
|
|
|
|
(call_expression
|
|
|
|
function: (scoped_identifier
|
|
|
|
path: (identifier) @_regex (#eq? @_regex "Regex")
|
|
|
|
name: (identifier) @_new (#eq? @_new "new"))
|
|
|
|
arguments: (arguments (raw_string_literal) @injection.content)
|
|
|
|
(#set! injection.language "regex"))
|
|
|
|
|
|
|
|
(call_expression
|
|
|
|
function: (scoped_identifier
|
|
|
|
path: (scoped_identifier (identifier) @_regex (#eq? @_regex "Regex") .)
|
|
|
|
name: (identifier) @_new (#eq? @_new "new"))
|
|
|
|
arguments: (arguments (raw_string_literal) @injection.content)
|
|
|
|
(#set! injection.language "regex"))
|
2022-09-03 00:26:42 +02:00
|
|
|
|
2023-04-27 07:37:17 +02:00
|
|
|
; Highlight SQL in `sqlx::query!()`, `sqlx::query_scalar!()`, and `sqlx::query_scalar_unchecked!()`
|
2022-09-03 00:26:42 +02:00
|
|
|
(macro_invocation
|
|
|
|
macro: (scoped_identifier
|
|
|
|
path: (identifier) @_sqlx (#eq? @_sqlx "sqlx")
|
2023-04-27 07:37:17 +02:00
|
|
|
name: (identifier) @_query (#match? @_query "^query(_scalar|_scalar_unchecked)?$"))
|
2022-09-03 00:26:42 +02:00
|
|
|
(token_tree
|
|
|
|
; Only the first argument is SQL
|
|
|
|
.
|
|
|
|
[(string_literal) (raw_string_literal)] @injection.content
|
|
|
|
)
|
|
|
|
(#set! injection.language "sql"))
|
|
|
|
|
2023-04-27 07:37:17 +02:00
|
|
|
; Highlight SQL in `sqlx::query_as!()` and `sqlx::query_as_unchecked!()`
|
2022-09-03 00:26:42 +02:00
|
|
|
(macro_invocation
|
|
|
|
macro: (scoped_identifier
|
|
|
|
path: (identifier) @_sqlx (#eq? @_sqlx "sqlx")
|
2023-04-27 07:37:17 +02:00
|
|
|
name: (identifier) @_query_as (#match? @_query_as "^query_as(_unchecked)?$"))
|
2023-03-10 23:57:52 +01: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
|
|
|
|
(_)
|
|
|
|
[(string_literal) (raw_string_literal)] @injection.content
|
|
|
|
)
|
|
|
|
(#set! injection.language "sql"))
|