mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-01-24 09:50:04 +08:00
205 lines
3.4 KiB
Scheme
Vendored
205 lines
3.4 KiB
Scheme
Vendored
; CREDITS @stumash (stuart.mashaal@gmail.com)
|
|
|
|
;; variables
|
|
|
|
(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
|
|
name: (identifier) @type)
|
|
|
|
(object_definition
|
|
name: (identifier) @type)
|
|
|
|
(trait_definition
|
|
name: (identifier) @type)
|
|
|
|
(type_definition
|
|
name: (type_identifier) @type)
|
|
|
|
; method definition
|
|
|
|
(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)))
|
|
|
|
; imports
|
|
|
|
(import_declaration
|
|
path: (identifier) @namespace)
|
|
((stable_identifier (identifier) @namespace))
|
|
|
|
((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_expression
|
|
function: (field_expression
|
|
field: (identifier) @method))
|
|
|
|
((call_expression
|
|
function: (identifier) @constructor)
|
|
(#lua-match? @constructor "^[A-Z]"))
|
|
|
|
(generic_function
|
|
function: (identifier) @function)
|
|
|
|
(
|
|
(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
|
|
|
|
[
|
|
(symbol_literal)
|
|
(string)
|
|
(character_literal)
|
|
(interpolated_string_expression)
|
|
] @string
|
|
|
|
(interpolation "$" @punctuation.special)
|
|
|
|
;; keywords
|
|
|
|
[
|
|
"abstract"
|
|
"case"
|
|
"class"
|
|
"extends"
|
|
"final"
|
|
"finally"
|
|
;; `forSome` existential types not implemented yet
|
|
"implicit"
|
|
"lazy"
|
|
;; `macro` not implemented yet
|
|
"object"
|
|
"override"
|
|
"package"
|
|
"private"
|
|
"protected"
|
|
"sealed"
|
|
"trait"
|
|
"type"
|
|
"val"
|
|
"var"
|
|
"with"
|
|
] @keyword
|
|
|
|
(null_literal) @keyword
|
|
(wildcard) @keyword
|
|
|
|
;; special keywords
|
|
|
|
"new" @keyword.operator
|
|
|
|
[
|
|
"else"
|
|
"if"
|
|
"match"
|
|
] @conditional
|
|
|
|
[
|
|
"("
|
|
")"
|
|
"["
|
|
"]"
|
|
"{"
|
|
"}"
|
|
] @punctuation.bracket
|
|
|
|
[
|
|
"."
|
|
","
|
|
] @punctuation.delimiter
|
|
|
|
[
|
|
"do"
|
|
"for"
|
|
"while"
|
|
"yield"
|
|
] @repeat
|
|
|
|
"def" @keyword.function
|
|
|
|
[
|
|
"=>"
|
|
"<-"
|
|
"@"
|
|
] @operator
|
|
|
|
"import" @include
|
|
|
|
[
|
|
"try"
|
|
"catch"
|
|
"throw"
|
|
] @exception
|
|
|
|
"return" @keyword.return
|
|
|
|
(comment) @comment
|
|
|
|
;; `case` is a conditional keyword in case_block
|
|
|
|
(case_block
|
|
(case_clause ("case") @conditional))
|