Skip to content

Commit

Permalink
replace new lsp for vlang (helix-editor#7760)
Browse files Browse the repository at this point in the history
* fix vlang grammar fetch and build fail

* update highlights.scm for v-analyzer

* Update languages.toml

Co-authored-by: Michael Davis <mcarsondavis@gmail.com>

* Update runtime/queries/v/highlights.scm

Co-authored-by: Michael Davis <mcarsondavis@gmail.com>

* update scm for new lsp

* gen doc lang-support.md

---------

Co-authored-by: Michael Davis <mcarsondavis@gmail.com>
  • Loading branch information
2 people authored and mtoohey31 committed Jun 2, 2024
1 parent be318e5 commit 3682a59
Show file tree
Hide file tree
Showing 5 changed files with 93 additions and 60 deletions.
2 changes: 1 addition & 1 deletion book/src/generated/lang-support.md
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@
| typescript |||| `typescript-language-server` |
| ungrammar || | | |
| uxntal || | | |
| v |||| `v` |
| v |||| `v-analyzer` |
| vala || | | `vala-language-server` |
| verilog ||| | `svlangserver` |
| vhdl || | | `vhdl_ls` |
Expand Down
4 changes: 2 additions & 2 deletions languages.toml
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ terraform-ls = { command = "terraform-ls", args = ["serve"] }
texlab = { command = "texlab" }
vala-language-server = { command = "vala-language-server" }
vhdl_ls = { command = "vhdl_ls", args = [] }
vlang-language-server = { command = "v", args = ["ls"] }
vlang-language-server = { command = "v-analyzer" }
vscode-css-language-server = { command = "vscode-css-language-server", args = ["--stdio"], config = { "provideFormatter" = true }}
vscode-html-language-server = { command = "vscode-html-language-server", args = ["--stdio"], config = { provideFormatter = true } }
vscode-json-language-server = { command = "vscode-json-language-server", args = ["--stdio"], config = { provideFormatter = true } }
Expand Down Expand Up @@ -1826,7 +1826,7 @@ indent = { tab-width = 4, unit = "\t" }

[[grammar]]
name = "v"
source = { git = "https://github.com/vlang/vls", subpath = "tree_sitter_v", rev = "66cf9d3086fb5ecc827cb32c64c5d812ab17d2c6" }
source = {git = "https://github.com/v-analyzer/v-analyzer", subpath = "tree_sitter_v", rev = "e14fdf6e661b10edccc744102e4ccf0b187aa8ad"}

[[language]]
name = "verilog"
Expand Down
136 changes: 85 additions & 51 deletions runtime/queries/v/highlights.scm
Original file line number Diff line number Diff line change
@@ -1,83 +1,112 @@
(comment) @comment

(module_clause
(identifier) @namespace)

(import_path
(import_name) @namespace)

(import_alias
(import_name) @namespace)

(enum_fetch
(reference_expression) @constant)

(enum_field_definition
(identifier) @constant)

(global_var_definition
(identifier) @constant)

(compile_time_if_expression
condition: (reference_expression) @constant)

(compile_time_if_expression
condition: (binary_expression
left: (reference_expression) @constant
right: (reference_expression) @constant))

(compile_time_if_expression
condition: (binary_expression
left: (reference_expression) @constant
right: (unary_expression (reference_expression) @constant)))

(label_reference) @label

(parameter_declaration
name: (identifier) @variable.parameter)
name: (identifier) @variable.parameter)
(receiver
name: (identifier) @variable.parameter)
(function_declaration
name: (identifier) @function)
name: (identifier) @function)
(function_declaration
receiver: (parameter_list)
name: (identifier) @function.method)
receiver: (receiver)
name: (identifier) @function.method)
(interface_method_definition
name: (identifier) @function.method)

(call_expression
function: (identifier) @function)
(call_expression
function: (selector_expression
field: (identifier) @function.method))
name: (selector_expression
field: (reference_expression) @function.method))

(field_identifier) @variable.other.member
(selector_expression
operand: (identifier) @variable
field: (identifier) @variable.other.member)
(call_expression
name: (reference_expression) @function)

(int_literal) @constant.numeric.integer
(struct_declaration
name: (identifier) @type)

(attribute_declaration) @attribute
(comment) @comment
[
(c_string_literal)
(raw_string_literal)
(interpreted_string_literal)
(string_interpolation)
(rune_literal)
] @string
(enum_declaration
name: (identifier) @type)

(escape_sequence) @constant.character.escape
(interface_declaration
name: (identifier) @type)

[
(pointer_type)
(array_type)
] @type
(type_declaration
name: (identifier) @type)

(const_spec name: (identifier) @constant)
(global_var_type_initializer name: (identifier) @constant)
(global_var_spec name: (identifier) @constant)
((identifier) @constant (#match? @constant "^[A-Z][A-Z\\d_]*$"))
(struct_field_declaration
name: (identifier) @variable.other.member)

(field_name) @variable.other.member

[
(generic_type)
(type_identifier)
] @constructor
(selector_expression
field: (reference_expression) @variable.other.member)

(builtin_type) @type.builtin
(int_literal) @constant.numeric.integer
(escape_sequence) @constant.character.escape

[
(true)
(false)
] @constant.builtin.boolean
(c_string_literal)
(raw_string_literal)
(interpreted_string_literal)
(string_interpolation)
(rune_literal)
] @string

(string_interpolation
(braced_interpolation_opening) @punctuation.bracket
(interpolated_expression) @embedded
(braced_interpolation_closing) @punctuation.bracket)

[
(module_identifier)
(import_path)
] @namespace
(attribute) @attribute

[
(pseudo_comptime_identifier)
(label_name)
] @label
(type_reference_expression)
] @type

[
(identifier)
] @variable

(true)
(false)
] @constant.builtin.boolean

[
"pub"
"assert"
"go"
"asm"
"defer"
"unsafe"
"sql"
(nil)
(none)
] @keyword

Expand Down Expand Up @@ -105,12 +134,17 @@
"lock"
"rlock"
"spawn"
"break"
"continue"
"go"
] @keyword.control

[
"if"
"$if"
"select"
"else"
"$else"
"match"
] @keyword.control.conditional

Expand Down Expand Up @@ -155,7 +189,7 @@
"]"
] @punctuation.bracket

(array) @punctuation.bracket
(array_creation) @punctuation.bracket

[
"++"
Expand Down
5 changes: 2 additions & 3 deletions runtime/queries/v/indents.scm
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,10 @@
(function_declaration)
(if_expression)
(match_expression)
(expression_case)
(default_case)
(for_statement)
(unsafe_expression)
(short_var_declaration)
(var_declaration)
(const_declaration)
] @indent

[
Expand Down
6 changes: 3 additions & 3 deletions runtime/queries/v/textobjects.scm
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
body: (block)? @test.inside) @test.around
(#match? @_name "^test"))

(fn_literal
(function_literal
body: (block)? @function.inside) @function.around

(parameter_list
Expand All @@ -17,9 +17,9 @@
((_) @parameter.inside) @parameter.around))

(struct_declaration
(struct_field_declaration_list) @class.inside) @class.around
(struct_field_declaration) @class.inside) @class.around

(struct_field_declaration_list
(struct_field_declaration
((_) @parameter.inside) @parameter.around)

(comment) @comment.inside
Expand Down

0 comments on commit 3682a59

Please sign in to comment.