helix/runtime/queries/cpp/highlights.scm

178 lines
3.7 KiB
Scheme
Raw Normal View History

; inherits: c
; Constants
(this) @variable.builtin
2025-05-10 21:00:05 +08:00
(null) @constant.builtin
; Types
(using_declaration ("using" "namespace" (identifier) @namespace))
(using_declaration ("using" "namespace" (qualified_identifier name: (identifier) @namespace)))
(namespace_definition name: (namespace_identifier) @namespace)
(namespace_identifier) @namespace
(auto) @type
"decltype" @type
(ref_qualifier ["&" "&&"] @type.builtin)
(reference_declarator ["&" "&&"] @type.builtin)
(abstract_reference_declarator ["&" "&&"] @type.builtin)
2025-06-16 21:04:22 +08:00
; -------
2021-04-08 22:18:25 +08:00
; Functions
2025-06-16 21:04:22 +08:00
; -------
; Support up to 4 levels of nesting of qualifiers
; i.e. a::b::c::d::func();
2021-04-08 22:18:25 +08:00
(call_expression
function: (qualified_identifier
2021-04-08 22:18:25 +08:00
name: (identifier) @function))
2025-06-16 21:04:22 +08:00
(call_expression
function: (qualified_identifier
name: (qualified_identifier
name: (identifier) @function)))
(call_expression
function: (qualified_identifier
name: (qualified_identifier
name: (qualified_identifier
name: (identifier) @function))))
(call_expression
function: (qualified_identifier
name: (qualified_identifier
name: (qualified_identifier
name: (qualified_identifier
name: (identifier) @function)))))
2021-04-08 22:18:25 +08:00
(template_function
name: (identifier) @function)
(template_method
name: (field_identifier) @function)
2025-06-16 21:04:22 +08:00
; Support up to 4 levels of nesting of qualifiers
; i.e. a::b::c::d::func();
2021-04-08 22:18:25 +08:00
(function_declarator
declarator: (qualified_identifier
2021-04-08 22:18:25 +08:00
name: (identifier) @function))
(function_declarator
declarator: (qualified_identifier
name: (qualified_identifier
name: (identifier) @function)))
(function_declarator
declarator: (qualified_identifier
name: (qualified_identifier
name: (qualified_identifier
name: (identifier) @function))))
2025-06-16 21:04:22 +08:00
(function_declarator
declarator: (qualified_identifier
name: (qualified_identifier
name: (qualified_identifier
name: (qualified_identifier
name: (identifier) @function)))))
2021-04-08 22:18:25 +08:00
(function_declarator
declarator: (field_identifier) @function)
2025-06-16 21:04:22 +08:00
; Constructors
(class_specifier
(type_identifier) @type
(field_declaration_list
(function_definition
(function_declarator
(identifier) @constructor)))
(#eq? @type @constructor))
(destructor_name "~" @constructor
(identifier) @constructor)
; Parameters
(parameter_declaration
declarator: (reference_declarator (identifier) @variable.parameter))
(optional_parameter_declaration
declarator: (identifier) @variable.parameter)
2021-04-08 22:18:25 +08:00
; Keywords
(template_argument_list (["<" ">"] @punctuation.bracket))
(template_parameter_list (["<" ">"] @punctuation.bracket))
(default_method_clause "default" @keyword)
"static_assert" @function.special
[
"<=>"
"[]"
"()"
] @operator
; These casts are parsed as function calls, but are not.
((identifier) @keyword (#eq? @keyword "static_cast"))
((identifier) @keyword (#eq? @keyword "dynamic_cast"))
((identifier) @keyword (#eq? @keyword "reinterpret_cast"))
((identifier) @keyword (#eq? @keyword "const_cast"))
[
"co_await"
"co_return"
"co_yield"
"concept"
"delete"
"new"
"operator"
"requires"
"using"
] @keyword
[
"catch"
"noexcept"
"throw"
"try"
] @keyword.control.exception
[
"and"
"and_eq"
"bitor"
"bitand"
"not"
"not_eq"
"or"
"or_eq"
"xor"
"xor_eq"
] @keyword.operator
[
"class"
"namespace"
"typename"
"template"
] @keyword.storage.type
[
"constexpr"
"constinit"
"consteval"
"mutable"
] @keyword.storage.modifier
; Modifiers that aren't plausibly type/storage related.
[
"explicit"
"friend"
"virtual"
(virtual_specifier) ; override/final
"private"
"protected"
"public"
"inline" ; C++ meaning differs from C!
] @keyword
2021-04-08 22:18:25 +08:00
; Strings
(raw_string_literal) @string