Sync highlight queries from nvim-treesitter

pull/481/head
Anton Sviridov 2023-01-08 12:38:00 +07:00
parent a7b8fa65cf
commit f6bc02526a
1 changed files with 185 additions and 42 deletions

@ -1,76 +1,219 @@
;; Annotations ; CREDITS @stumash (stuart.mashaal@gmail.com)
"@" @operator ;; variables
;; Types (identifier) @variable
((identifier) @variable.builtin
(#lua-match? @variable.builtin "^this$"))
(interpolation) @none
; Assume other uppercase names constants.
; NOTE: In order to distinguish constants we highlight
; all the identifiers that are uppercased. But this solution
; is not suitable for all occurrences e.g. it will highlight
; an uppercased method as a constant if used with no params.
; Introducing highlighting for those specific cases, is probably
; best way to resolve the issue.
((identifier) @constant (#lua-match? @constant "^[A-Z]"))
;; types
(type_identifier) @type
(class_definition (class_definition
name: (identifier) @type) name: (identifier) @type)
(trait_definition
(enum_definition
name: (identifier) @type) name: (identifier) @type)
(object_definition (object_definition
name: (identifier) @type) name: (identifier) @type)
(type_identifier) @type (trait_definition
name: (identifier) @type)
;; Variables (type_definition
name: (type_identifier) @type.definition)
((identifier) @constant ; method definition
(#match? @constant "^_*[A-Z][A-Z\\d_]+$"))
(identifier) @variable (class_definition
body: (template_body
(function_definition
name: (identifier) @method)))
(object_definition
body: (template_body
(function_definition
name: (identifier) @method)))
(trait_definition
body: (template_body
(function_definition
name: (identifier) @method)))
;; Literals ; imports
[ (import_declaration
(integer_literal) path: (identifier) @namespace)
(floating_point_literal) ((stable_identifier (identifier) @namespace))
] @number
((import_declaration
path: (identifier) @type) (#lua-match? @type "^[A-Z]"))
((stable_identifier (identifier) @type) (#lua-match? @type "^[A-Z]"))
((import_selectors (identifier) @type) (#lua-match? @type "^[A-Z]"))
; method invocation
(call_expression
function: (identifier) @function.call)
(call_expression
function: (field_expression
field: (identifier) @method.call))
((call_expression
function: (identifier) @constructor)
(#lua-match? @constructor "^[A-Z]"))
(generic_function
function: (identifier) @function.call)
(
(identifier) @function.builtin
(#lua-match? @function.builtin "^super$")
)
; function definitions
(function_definition
name: (identifier) @function)
(parameter
name: (identifier) @parameter)
; expressions
(field_expression field: (identifier) @property)
(field_expression value: (identifier) @type
(#lua-match? @type "^[A-Z]"))
(infix_expression operator: (identifier) @operator)
(infix_expression operator: (operator_identifier) @operator)
(infix_type operator: (operator_identifier) @operator)
(infix_type operator: (operator_identifier) @operator)
; literals
(boolean_literal) @boolean
(integer_literal) @number
(floating_point_literal) @float
[ [
(character_literal) (symbol_literal)
(string) (string)
(character_literal)
(interpolated_string_expression)
] @string ] @string
[ (interpolation "$" @punctuation.special)
(boolean_literal)
(null_literal)
] @constant.builtin
(comment) @comment
(opaque_modifier) @keyword ;; keywords
;; Keywords (opaque_modifier) @type.qualifier
[ [
"abstract"
"case" "case"
"catch"
"class" "class"
"def" "enum"
"do"
"else"
"extends" "extends"
"final"
"finally" "finally"
"for" ;; `forSome` existential types not implemented yet
"if" ;; `macro` not implemented yet
"implicit"
"import"
"lazy"
"match"
"new"
"object" "object"
"override" "override"
"package" "package"
"trait"
"type"
"val"
"var"
"with"
"given"
"end"
] @keyword
[
"abstract"
"final"
"implicit"
"using"
"lazy"
"private" "private"
"protected" "protected"
"return"
"sealed" "sealed"
"throw" ] @type.qualifier
"trait"
"try" (null_literal) @constant.builtin
(wildcard) @parameter
(annotation) @attribute
;; special keywords
"new" @keyword.operator
[
"else"
"if"
"match"
] @conditional
[
"("
")"
"["
"]"
"{"
"}"
] @punctuation.bracket
[
"."
","
] @punctuation.delimiter
[
"do"
"for"
"while" "while"
"with" "yield"
] @keyword ] @repeat
"def" @keyword.function
[
"=>"
"<-"
"@"
] @operator
"import" @include
[
"try"
"catch"
"throw"
] @exception
"return" @keyword.return
(comment) @comment @spell
;; `case` is a conditional keyword in case_block
(case_block
(case_clause ("case") @conditional))