Update Swift Grammar and Queries (#10802)

This commit is contained in:
Arturs Krumins 2024-06-07 19:29:42 +02:00 committed by GitHub
parent 44504b720b
commit aa1630a41a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 78 additions and 13 deletions

View File

@ -190,7 +190,7 @@
| supercollider | ✓ | | | | | supercollider | ✓ | | | |
| svelte | ✓ | | ✓ | `svelteserver` | | svelte | ✓ | | ✓ | `svelteserver` |
| sway | ✓ | ✓ | ✓ | `forc` | | sway | ✓ | ✓ | ✓ | `forc` |
| swift | ✓ | | | `sourcekit-lsp` | | swift | ✓ | | | `sourcekit-lsp` |
| t32 | ✓ | | | | | t32 | ✓ | | | |
| tablegen | ✓ | ✓ | ✓ | | | tablegen | ✓ | ✓ | ✓ | |
| tact | ✓ | ✓ | ✓ | | | tact | ✓ | ✓ | ✓ | |

View File

@ -1908,16 +1908,17 @@ language-servers = [ "r" ]
name = "swift" name = "swift"
scope = "source.swift" scope = "source.swift"
injection-regex = "swift" injection-regex = "swift"
file-types = ["swift"] file-types = ["swift", "swiftinterface"]
roots = [ "Package.swift" ] roots = [ "Package.swift" ]
comment-token = "//" comment-token = "//"
block-comment-tokens = { start = "/*", end = "*/" } block-comment-tokens = { start = "/*", end = "*/" }
formatter = { command = "swift-format", args = [ "--configuration", ".swift-format"] }
auto-format = true auto-format = true
language-servers = [ "sourcekit-lsp" ] language-servers = [ "sourcekit-lsp" ]
[[grammar]] [[grammar]]
name = "swift" name = "swift"
source = { git = "https://github.com/alex-pinkus/tree-sitter-swift", rev = "b1b66955d420d5cf5ff268ae552f0d6e43ff66e1" } source = { git = "https://github.com/alex-pinkus/tree-sitter-swift", rev = "57c1c6d6ffa1c44b330182d41717e6fe37430704" }
[[language]] [[language]]
name = "erb" name = "erb"

View File

@ -1,4 +1,4 @@
; Upstream: https://github.com/alex-pinkus/tree-sitter-swift/blob/1c586339fb00014b23d6933f2cc32b588a226f3b/queries/highlights.scm ; Upstream: https://github.com/alex-pinkus/tree-sitter-swift/blob/57c1c6d6ffa1c44b330182d41717e6fe37430704/queries/highlights.scm
(line_string_literal (line_string_literal
["\\(" ")"] @punctuation.special) ["\\(" ")"] @punctuation.special)
@ -10,6 +10,7 @@
(attribute) @variable (attribute) @variable
(type_identifier) @type (type_identifier) @type
(self_expression) @variable.builtin (self_expression) @variable.builtin
(user_type (type_identifier) @variable.builtin (#eq? @variable.builtin "Self"))
; Declarations ; Declarations
"func" @keyword.function "func" @keyword.function
@ -23,7 +24,9 @@
] @keyword ] @keyword
(function_declaration (simple_identifier) @function.method) (function_declaration (simple_identifier) @function.method)
(function_declaration "init" @constructor) (init_declaration ["init" @constructor])
(deinit_declaration ["deinit" @constructor])
(throws) @keyword (throws) @keyword
"async" @keyword "async" @keyword
"await" @keyword "await" @keyword
@ -48,10 +51,23 @@
"override" "override"
"convenience" "convenience"
"required" "required"
"some" "mutating"
"associatedtype"
"package"
"any" "any"
] @keyword ] @keyword
(opaque_type ["some" @keyword])
(existential_type ["any" @keyword])
(precedence_group_declaration
["precedencegroup" @keyword]
(simple_identifier) @type)
(precedence_group_attribute
(simple_identifier) @keyword
[(simple_identifier) @type
(boolean_literal) @constant.builtin.boolean])
[ [
(getter_specifier) (getter_specifier)
(setter_specifier) (setter_specifier)
@ -73,6 +89,10 @@
((navigation_expression ((navigation_expression
(simple_identifier) @type) ; SomeType.method(): highlight SomeType as a type (simple_identifier) @type) ; SomeType.method(): highlight SomeType as a type
(#match? @type "^[A-Z]")) (#match? @type "^[A-Z]"))
(call_expression (simple_identifier) @keyword (#eq? @keyword "defer")) ; defer { ... }
(try_operator) @operator
(try_operator ["try" @keyword])
(directive) @function.macro (directive) @function.macro
(diagnostic) @function.macro (diagnostic) @function.macro
@ -136,10 +156,8 @@
; Operators ; Operators
[ [
"try"
"try?"
"try!"
"!" "!"
"?"
"+" "+"
"-" "-"
"*" "*"
@ -171,3 +189,8 @@
"..." "..."
(custom_operator) (custom_operator)
] @operator ] @operator
(value_parameter_pack ["each" @keyword])
(value_pack_expansion ["repeat" @keyword])
(type_parameter_pack ["each" @keyword])
(type_pack_expansion ["repeat" @keyword])

View File

@ -0,0 +1,6 @@
; Upstream: https://github.com/alex-pinkus/tree-sitter-swift/blob/57c1c6d6ffa1c44b330182d41717e6fe37430704/queries/injections.scm
; Parse regex syntax within regex literals
((regex_literal) @injection.content
(#set! injection.language "regex"))

View File

@ -1,7 +1,19 @@
; Upstream: https://github.com/alex-pinkus/tree-sitter-swift/blob/57c1c6d6ffa1c44b330182d41717e6fe37430704/queries/locals.scm
(import_declaration (identifier) @definition.import)
(function_declaration name: (simple_identifier) @definition.function)
; Scopes
[ [
(for_statement)
(while_statement)
(repeat_while_statement)
(do_statement)
(if_statement)
(guard_statement)
(switch_statement)
(property_declaration)
(function_declaration) (function_declaration)
(class_declaration)
(protocol_declaration)
(lambda_literal)
] @local.scope ] @local.scope
(parameter name: (simple_identifier) @local.definition)
(simple_identifier) @local.reference

View File

@ -0,0 +1,23 @@
(class_declaration
body: (_) @class.inside) @class.around
(protocol_declaration
body: (_) @class.inside) @class.around
(function_declaration
body: (_) @function.inside) @function.around
(parameter
(_) @parameter.inside) @parameter.around
(lambda_parameter
(_) @parameter.inside) @parameter.around
[
(comment)
(multiline_comment)
] @comment.inside
(comment)+ @comment.around
(multiline_comment) @comment.around