Skip to content

Commit

Permalink
Upgrade rescript tree sitter & highlights (helix-editor#4356)
Browse files Browse the repository at this point in the history
Co-authored-by: Michael Davis <mcarsondavis@gmail.com>
  • Loading branch information
2 people authored and pathwave committed Nov 4, 2022
1 parent 6b00d33 commit 9966e41
Show file tree
Hide file tree
Showing 5 changed files with 169 additions and 24 deletions.
2 changes: 1 addition & 1 deletion languages.toml
Original file line number Diff line number Diff line change
Expand Up @@ -1140,7 +1140,7 @@ indent = { tab-width = 2, unit = " " }

[[grammar]]
name = "rescript"
source = { git = "https://github.com/jaredramirez/tree-sitter-rescript", rev = "4cd7ba91696886fdaca086fb32b5fd8cc294a129" }
source = { git = "https://github.com/jaredramirez/tree-sitter-rescript", rev = "65609807c628477f3b94052e7ef895885ac51c3c" }

[[language]]
name = "erlang"
Expand Down
84 changes: 63 additions & 21 deletions runtime/queries/rescript/highlights.scm
Original file line number Diff line number Diff line change
Expand Up @@ -10,20 +10,23 @@
[
(type_identifier)
(unit_type)
"list"
] @type

(list ["list{" "}"] @type)
(list_pattern ["list{" "}"] @type)

[
(variant_identifier)
(polyvar_identifier)
] @constant
] @constructor

(property_identifier) @variable.other.member
(record_type_field (property_identifier) @type)
(object_type (field (property_identifier) @type))
(record_field (property_identifier) @variable.other.member)
(object (field (property_identifier) @variable.other.member))
(member_expression (property_identifier) @variable.other.member)
(module_identifier) @namespace

(jsx_identifier) @tag
(jsx_attribute (property_identifier) @variable.parameter)

; Parameters
;----------------

Expand All @@ -42,8 +45,8 @@
"${" @punctuation.bracket
"}" @punctuation.bracket) @embedded

(character) @constant.character
(escape_sequence) @constant.character.escape
(character) @string.special
(escape_sequence) @string.special

; Other literals
;---------------
Expand All @@ -60,11 +63,13 @@
; Functions
;----------

; parameter(s) in parens
[
(formal_parameters (value_identifier))
(parameter (value_identifier))
(labeled_parameter (value_identifier))
] @variable.parameter

; single parameter with no parens
(function parameter: (value_identifier) @variable.parameter)

; Meta
Expand All @@ -74,47 +79,65 @@
"@"
"@@"
(decorator_identifier)
] @label
] @keyword.directive

(extension_identifier) @keyword
("%") @keyword

; Misc
;-----

(subscript_expression index: (string) @variable.other.member)
; (subscript_expression index: (string) @attribute)
(polyvar_type_pattern "#" @constant)

[
("include")
("open")
] @keyword
] @keyword.control.import

[
"as"
"export"
"external"
"let"
"module"
"mutable"
"private"
"rec"
"type"
"and"
] @keyword
"assert"
"async"
"await"
"with"
"unpack"
] @keyword.storage.type

"mutable" @keyword.storage.modifier

[
"if"
"else"
"switch"
] @keyword
"when"
] @keyword.control.conditional

[
"exception"
"try"
"catch"
"raise"
] @keyword
] @keyword.control.exception

(call_expression
function: (value_identifier) @keyword.control.exception
(#eq? @keyword.control.exception "raise"))

[
"for"
"in"
"to"
"downto"
"while"
] @keyword.control.conditional

[
"."
Expand All @@ -129,17 +152,15 @@
"-"
"-."
"*"
"**"
"*."
"/"
"/."
"<"
"<="
"=="
"==="
"!"
"!="
"!=="
">"
">="
"&&"
"||"
Expand All @@ -151,6 +172,10 @@
(uncurry)
] @operator

; Explicitly enclose these operators with binary_expression
; to avoid confusion with JSX tag delimiters
(binary_expression ["<" ">" "/"] @operator)

[
"("
")"
Expand All @@ -172,7 +197,24 @@
"~"
"?"
"=>"
".."
"..."
] @punctuation
] @punctuation.special

(ternary_expression ["?" ":"] @operator)

; JSX
;----------
(jsx_identifier) @tag
(jsx_element
open_tag: (jsx_opening_element ["<" ">"] @punctuation.special))
(jsx_element
close_tag: (jsx_closing_element ["<" "/" ">"] @punctuation.special))
(jsx_self_closing_element ["/" ">" "<"] @punctuation.special)
(jsx_fragment [">" "<" "/"] @punctuation.special)
(jsx_attribute (property_identifier) @attribute)

; Error
;----------

(ERROR) @keyword.control.exception
2 changes: 1 addition & 1 deletion runtime/queries/rescript/injections.scm
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,4 @@
(#set! injection.language "javascript"))

((raw_gql) @injection.content
(#set! injection.language "graphql"))
(#set! injection.language "graphql"))
7 changes: 7 additions & 0 deletions runtime/queries/rescript/locals.scm
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
(switch_expression) @local.scope
(if_expression) @local.scope

; Definitions
;------------
(type_declaration) @local.defintion
(let_binding) @local.defintion
98 changes: 97 additions & 1 deletion runtime/queries/rescript/textobjects.scm
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,110 @@

(module_declaration definition: ((_) @class.inside)) @class.around

; Blocks
;-------

(block (_) @function.inside) @function.around

; Functions
;----------

(function body: (_) @function.inside) @function.around

; Calls
;------

(call_expression arguments: ((_) @parameter.inside)) @parameter.around

; Comments
;---------

(comment) @comment.inside

(comment)+ @comment.around

; Parameters
;-----------

(function parameter: (_) @parameter.inside @parameter.around)

(formal_parameters
","
. (_) @parameter.inside
@parameter.around)
(formal_parameters
. (_) @parameter.inside
. ","?
@parameter.around)

(arguments
"," @_arguments_start
. (_) @parameter.inside
@parameter.around)
(arguments
. (_) @parameter.inside
. ","?
@parameter.around)

(function_type_parameters
","
. (_) @parameter.inside
@parameter.around)
(function_type_parameters
. (_) @parameter.inside
. ","?
@parameter.around)

(functor_parameters
","
. (_) @parameter.inside
@parameter.around)
(functor_parameters
. (_) @parameter.inside
. ","?
@parameter.around)

(type_parameters
","
. (_) @parameter.inside
@parameter.around)
(type_parameters
. (_) @parameter.inside
. ","?
@parameter.around)

(type_arguments
","
. (_) @parameter.inside
@parameter.around)
(type_arguments
. (_) @parameter.inside
. ","?
@parameter.around)

(decorator_arguments
","
. (_) @parameter.inside
@parameter.around)
(decorator_arguments
. (_) @parameter.inside
. ","?
@parameter.around)

(variant_parameters
","
. (_) @parameter.inside
@parameter.around)
(variant_parameters
. (_) @parameter.inside
. ","?
@parameter.around)

(polyvar_parameters
","
. (_) @parameter.inside
@parameter.around)
(polyvar_parameters
. (_) @parameter.inside
. ","?
@parameter.around)

0 comments on commit 9966e41

Please sign in to comment.