summaryrefslogtreecommitdiff
path: root/runtime/queries/javascript/highlights.scm
diff options
context:
space:
mode:
authorMichael Davis2022-08-03 05:09:44 +0000
committerGitHub2022-08-03 05:09:44 +0000
commit08b442f4cc962fd83a41754aba41f742acd1e8dc (patch)
tree1b4c14d9504bb6311d134bac6fac1399b9401d1a /runtime/queries/javascript/highlights.scm
parent69f84e25165d62d0f38bcc80bf9108f9c0802cad (diff)
Inherit javascript/typescript from common 'ecma' queries (#3301)
JavaScript queries now contain a few lines that prevent them from being used whole-sale in typescript with `; inherits: javascript`. Here we follow nvim-treesitter's way of using a fake 'ecma' language as a common base for JavaScript and TypeScript to share as much as we can.
Diffstat (limited to 'runtime/queries/javascript/highlights.scm')
-rw-r--r--runtime/queries/javascript/highlights.scm221
1 files changed, 1 insertions, 220 deletions
diff --git a/runtime/queries/javascript/highlights.scm b/runtime/queries/javascript/highlights.scm
index 9e30d0e7..58843479 100644
--- a/runtime/queries/javascript/highlights.scm
+++ b/runtime/queries/javascript/highlights.scm
@@ -1,52 +1,3 @@
-; Special identifiers
-;--------------------
-
-([
- (identifier)
- (shorthand_property_identifier)
- (shorthand_property_identifier_pattern)
- ] @constant
- (#match? @constant "^[A-Z_][A-Z\\d_]+$"))
-
-
-((identifier) @constructor
- (#match? @constructor "^[A-Z]"))
-
-((identifier) @variable.builtin
- (#match? @variable.builtin "^(arguments|module|console|window|document)$")
- (#is-not? local))
-
-((identifier) @function.builtin
- (#eq? @function.builtin "require")
- (#is-not? local))
-
-; Function and method definitions
-;--------------------------------
-
-(function
- name: (identifier) @function)
-(function_declaration
- name: (identifier) @function)
-(method_definition
- name: (property_identifier) @function.method)
-
-(pair
- key: (property_identifier) @function.method
- value: [(function) (arrow_function)])
-
-(assignment_expression
- left: (member_expression
- property: (property_identifier) @function.method)
- right: [(function) (arrow_function)])
-
-(variable_declarator
- name: (identifier) @function
- value: [(function) (arrow_function)])
-
-(assignment_expression
- left: (identifier) @function
- right: [(function) (arrow_function)])
-
; Function and method parameters
;-------------------------------
@@ -84,174 +35,4 @@
(arrow_function
parameter: (identifier) @variable.parameter)
-; Function and method calls
-;--------------------------
-
-(call_expression
- function: (identifier) @function)
-
-(call_expression
- function: (member_expression
- property: (property_identifier) @function.method))
-
-; Variables
-;----------
-
-(identifier) @variable
-
-; Properties
-;-----------
-
-(property_identifier) @variable.other.member
-(shorthand_property_identifier) @variable.other.member
-(shorthand_property_identifier_pattern) @variable.other.member
-
-; Literals
-;---------
-
-(this) @variable.builtin
-(super) @variable.builtin
-
-[
- (true)
- (false)
- (null)
- (undefined)
-] @constant.builtin
-
-(comment) @comment
-
-[
- (string)
- (template_string)
-] @string
-
-(regex) @string.regexp
-(number) @constant.numeric.integer
-
-; Tokens
-;-------
-
-(template_substitution
- "${" @punctuation.special
- "}" @punctuation.special) @embedded
-
-[
- ";"
- "?."
- "."
- ","
-] @punctuation.delimiter
-
-[
- "-"
- "--"
- "-="
- "+"
- "++"
- "+="
- "*"
- "*="
- "**"
- "**="
- "/"
- "/="
- "%"
- "%="
- "<"
- "<="
- "<<"
- "<<="
- "="
- "=="
- "==="
- "!"
- "!="
- "!=="
- "=>"
- ">"
- ">="
- ">>"
- ">>="
- ">>>"
- ">>>="
- "~"
- "^"
- "&"
- "|"
- "^="
- "&="
- "|="
- "&&"
- "||"
- "??"
- "&&="
- "||="
- "??="
- "..."
-] @operator
-
-(ternary_expression ["?" ":"] @operator)
-
-[
- "("
- ")"
- "["
- "]"
- "{"
- "}"
-] @punctuation.bracket
-
-[
- "as"
- "async"
- "debugger"
- "delete"
- "extends"
- "from"
- "function"
- "get"
- "in"
- "instanceof"
- "new"
- "of"
- "set"
- "static"
- "target"
- "try"
- "typeof"
- "void"
- "with"
-] @keyword
-
-[
- "class"
- "let"
- "const"
- "var"
-] @keyword.storage.type
-
-[
- "switch"
- "case"
- "default"
- "if"
- "else"
- "yield"
- "throw"
- "finally"
- "return"
- "catch"
- "continue"
- "while"
- "break"
- "for"
- "do"
- "await"
-] @keyword.control
-
-[
- "import"
- "export"
-] @keyword.control.import
-
+; inherits: ecma