Skip to content

Commit

Permalink
chore(solidity): update to newest grammar and fix queries (#12457)
Browse files Browse the repository at this point in the history
  • Loading branch information
beeb authored Jan 16, 2025
1 parent 19f7bc9 commit 29dda14
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 53 deletions.
2 changes: 1 addition & 1 deletion languages.toml
Original file line number Diff line number Diff line change
Expand Up @@ -1951,7 +1951,7 @@ language-servers = [ "solc" ]

[[grammar]]
name = "solidity"
source = { git = "https://github.com/JoranHonig/tree-sitter-solidity", rev = "08338dcee32603383fcef08f36321900bb7a354b" }
source = { git = "https://github.com/JoranHonig/tree-sitter-solidity", rev = "f7f5251a3f5b1d04f0799b3571b12918af177fc8" }

[[language]]
name = "gleam"
Expand Down
77 changes: 32 additions & 45 deletions runtime/queries/solidity/highlights.scm
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,8 @@
(pragma_directive) @keyword.directive
(solidity_version_comparison_operator _ @keyword.directive)


; Literals
; --------

[
(string)
(hex_string_literal)
Expand All @@ -27,18 +25,17 @@

(comment) @comment


; Definitions and references
; -----------

(type_name) @type

[
(primitive_type)
(number_unit)
] @type.builtin

(user_defined_type (identifier) @type)
(user_defined_type (_) @type)
(user_defined_type_definition name: (identifier) @type)
(type_alias (identifier) @type)

; Color payable in payable address conversion as type and not as keyword
Expand All @@ -47,24 +44,15 @@
(type_name "(" @punctuation.bracket "=>" @punctuation.delimiter ")" @punctuation.bracket)

; Definitions
(struct_declaration
name: (identifier) @type)
(enum_declaration
name: (identifier) @type)
(contract_declaration
name: (identifier) @type)
(library_declaration
name: (identifier) @type)
(interface_declaration
name: (identifier) @type)
(event_definition
name: (identifier) @type)

(function_definition
name: (identifier) @function)

(modifier_definition
name: (identifier) @function)
(struct_declaration name: (identifier) @type)
(enum_declaration name: (identifier) @type)
(contract_declaration name: (identifier) @type)
(library_declaration name: (identifier) @type)
(interface_declaration name: (identifier) @type)
(event_definition name: (identifier) @type)
(error_declaration name: (identifier) @type)
(function_definition name: (identifier) @function)
(modifier_definition name: (identifier) @function)
(yul_evm_builtin) @function.builtin

; Use constructor coloring for special functions
Expand All @@ -75,30 +63,37 @@

(struct_member name: (identifier) @variable.other.member)
(enum_value) @constant
; SCREAMING_SNAKE_CASE identifier are constants
((identifier) @constant (#match? @constant "^[A-Z][A-Z_]+$"))

; Invocations
(emit_statement . (identifier) @type)
(revert_statement error: (identifier) @type)
(modifier_invocation (identifier) @function)
(emit_statement name: (expression (identifier) @type))
(revert_statement error: (expression (identifier) @type))
(modifier_invocation . (_) @function)

(call_expression . (member_expression property: (identifier) @function.method))
(call_expression . (identifier) @function)
(call_expression . (_(member_expression property: (_) @function.method)))
(call_expression . (expression (identifier) @function))

; Function parameters
(call_struct_argument name: (identifier) @field)
(event_parameter name: (identifier) @variable.parameter)
(parameter name: (identifier) @variable.parameter)

; Yul functions
(yul_function_call function: (yul_identifier) @function)
(yul_function_definition . (yul_identifier) @function (yul_identifier) @variable.parameter)

(yul_function_call function: (_) @function)
(yul_function_definition
("function" (yul_identifier) @function "(" (
(yul_identifier) @variable.parameter ("," (yul_identifier) @variable.parameter)*
)
)
)

; Structs and members
(member_expression property: (identifier) @variable.other.member)
(struct_expression type: ((identifier) @type .))
(struct_expression type: ((expression (identifier)) @type .))
(struct_field_assignment name: (identifier) @variable.other.member)


; Tokens
; -------

Expand All @@ -113,17 +108,16 @@
"struct"
"enum"
"event"
"type"
"assembly"
"emit"

"public"
"internal"
"private"
"external"
"pure"
"view"
"payable"

"modifier"
"var"
"let"
Expand All @@ -137,6 +131,8 @@
"storage"
"calldata"
"constant"
"transient"
(immutable)
] @keyword.storage.modifier

[
Expand Down Expand Up @@ -175,7 +171,6 @@
(event_parameter "indexed" @keyword)

; Punctuation

[
"("
")"
Expand All @@ -185,7 +180,6 @@
"}"
] @punctuation.bracket


[
"."
","
Expand All @@ -194,14 +188,11 @@
"=>"
] @punctuation.delimiter


; Operators

[
"&&"
"||"
">>"
">>>"
"<<"
"&"
"^"
Expand All @@ -216,15 +207,12 @@
"<="
"=="
"!="
"!=="
">="
">"
"!"
"~"
"-"
"+"
"delete"
"new"
"++"
"--"
"+="
Expand All @@ -244,10 +232,9 @@
"new"
] @keyword.operator

; TODO: move to top when order swapped
; identifiers
; -----------
((identifier) @variable.builtin
(#match? @variable.builtin "^(this|msg|block|tx)$"))
((identifier) @variable.builtin (#any-of? @variable.builtin "this" "msg" "block" "tx"))
(identifier) @variable
(yul_identifier) @variable

8 changes: 4 additions & 4 deletions runtime/queries/solidity/locals.scm
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
(function_definition) @local.scope
(constructor_definition) @local.scope
(block_statement) @local.scope

(function_definition (parameter name: (identifier) @local.definition))
(constructor_definition (parameter name: (identifier) @local.definition))
(variable_declaration name: (identifier) @local.definition)

; still have to support tuple assignments
(assignment_expression left: (identifier) @local.definition)

(identifier) @local.reference
(identifier) @local.reference
7 changes: 4 additions & 3 deletions runtime/queries/solidity/textobjects.scm
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
((parameter) @parameter.inside . ","? @parameter.around) @parameter.around)

(return_type_definition
((parameter) @parameter.inside . ","? @parameter.around) @parameter.around)
((parameter) @entry.inside . ","? @entry.around) @entry.around)

(modifier_definition
((parameter) @parameter.inside . ","? @parameter.around) @parameter.around)
Expand All @@ -29,13 +29,13 @@
((error_parameter) @parameter.inside . ","? @parameter.around) @parameter.around)

(call_argument
((call_struct_argument) @parameter.inside . ","? @parameter.around) @parameter.around)
((call_struct_argument) @entry.inside . ","? @entry.around) @entry.around)

(call_expression
((call_argument) @parameter.inside . ","? @parameter.around) @parameter.around)

(variable_declaration_tuple
((variable_declaration) @parameter.inside . ","? @parameter.around) @parameter.around)
((variable_declaration) @entry.inside . ","? @entry.around) @entry.around)

(emit_statement
((call_argument) @parameter.inside . ","? @parameter.around) @parameter.around)
Expand All @@ -52,3 +52,4 @@
(comment) @comment.inside

(comment)+ @comment.around

0 comments on commit 29dda14

Please sign in to comment.