mirror of
https://github.com/nvim-treesitter/nvim-treesitter.git
synced 2026-07-01 19:17:02 -04:00
fix(python): don't highlight parameter name as builtin (#7732)
This commit is contained in:
parent
178a68b7ff
commit
683816f147
3 changed files with 77 additions and 65 deletions
|
|
@ -65,61 +65,6 @@
|
||||||
(identifier) @type))
|
(identifier) @type))
|
||||||
(#eq? @_isinstance "isinstance"))
|
(#eq? @_isinstance "isinstance"))
|
||||||
|
|
||||||
; Normal parameters
|
|
||||||
(parameters
|
|
||||||
(identifier) @variable.parameter)
|
|
||||||
|
|
||||||
; Lambda parameters
|
|
||||||
(lambda_parameters
|
|
||||||
(identifier) @variable.parameter)
|
|
||||||
|
|
||||||
(lambda_parameters
|
|
||||||
(tuple_pattern
|
|
||||||
(identifier) @variable.parameter))
|
|
||||||
|
|
||||||
; Default parameters
|
|
||||||
(keyword_argument
|
|
||||||
name: (identifier) @variable.parameter)
|
|
||||||
|
|
||||||
; Naming parameters on call-site
|
|
||||||
(default_parameter
|
|
||||||
name: (identifier) @variable.parameter)
|
|
||||||
|
|
||||||
(typed_parameter
|
|
||||||
(identifier) @variable.parameter)
|
|
||||||
|
|
||||||
(typed_default_parameter
|
|
||||||
name: (identifier) @variable.parameter)
|
|
||||||
|
|
||||||
; Variadic parameters *args, **kwargs
|
|
||||||
(parameters
|
|
||||||
(list_splat_pattern ; *args
|
|
||||||
(identifier) @variable.parameter))
|
|
||||||
|
|
||||||
(parameters
|
|
||||||
(dictionary_splat_pattern ; **kwargs
|
|
||||||
(identifier) @variable.parameter))
|
|
||||||
|
|
||||||
; Typed variadic parameters
|
|
||||||
(parameters
|
|
||||||
(typed_parameter
|
|
||||||
(list_splat_pattern ; *args: type
|
|
||||||
(identifier) @variable.parameter)))
|
|
||||||
|
|
||||||
(parameters
|
|
||||||
(typed_parameter
|
|
||||||
(dictionary_splat_pattern ; *kwargs: type
|
|
||||||
(identifier) @variable.parameter)))
|
|
||||||
|
|
||||||
; Lambda parameters
|
|
||||||
(lambda_parameters
|
|
||||||
(list_splat_pattern
|
|
||||||
(identifier) @variable.parameter))
|
|
||||||
|
|
||||||
(lambda_parameters
|
|
||||||
(dictionary_splat_pattern
|
|
||||||
(identifier) @variable.parameter))
|
|
||||||
|
|
||||||
; Literals
|
; Literals
|
||||||
(none) @constant.builtin
|
(none) @constant.builtin
|
||||||
|
|
||||||
|
|
@ -128,12 +73,6 @@
|
||||||
(false)
|
(false)
|
||||||
] @boolean
|
] @boolean
|
||||||
|
|
||||||
((identifier) @variable.builtin
|
|
||||||
(#eq? @variable.builtin "self"))
|
|
||||||
|
|
||||||
((identifier) @variable.builtin
|
|
||||||
(#eq? @variable.builtin "cls"))
|
|
||||||
|
|
||||||
(integer) @number
|
(integer) @number
|
||||||
|
|
||||||
(float) @number.float
|
(float) @number.float
|
||||||
|
|
@ -369,6 +308,67 @@
|
||||||
"bool" "int" "float" "complex" "list" "tuple" "range" "str" "bytes" "bytearray" "memoryview"
|
"bool" "int" "float" "complex" "list" "tuple" "range" "str" "bytes" "bytearray" "memoryview"
|
||||||
"set" "frozenset" "dict" "type" "object"))
|
"set" "frozenset" "dict" "type" "object"))
|
||||||
|
|
||||||
|
; Normal parameters
|
||||||
|
(parameters
|
||||||
|
(identifier) @variable.parameter)
|
||||||
|
|
||||||
|
; Lambda parameters
|
||||||
|
(lambda_parameters
|
||||||
|
(identifier) @variable.parameter)
|
||||||
|
|
||||||
|
(lambda_parameters
|
||||||
|
(tuple_pattern
|
||||||
|
(identifier) @variable.parameter))
|
||||||
|
|
||||||
|
; Default parameters
|
||||||
|
(keyword_argument
|
||||||
|
name: (identifier) @variable.parameter)
|
||||||
|
|
||||||
|
; Naming parameters on call-site
|
||||||
|
(default_parameter
|
||||||
|
name: (identifier) @variable.parameter)
|
||||||
|
|
||||||
|
(typed_parameter
|
||||||
|
(identifier) @variable.parameter)
|
||||||
|
|
||||||
|
(typed_default_parameter
|
||||||
|
name: (identifier) @variable.parameter)
|
||||||
|
|
||||||
|
; Variadic parameters *args, **kwargs
|
||||||
|
(parameters
|
||||||
|
(list_splat_pattern ; *args
|
||||||
|
(identifier) @variable.parameter))
|
||||||
|
|
||||||
|
(parameters
|
||||||
|
(dictionary_splat_pattern ; **kwargs
|
||||||
|
(identifier) @variable.parameter))
|
||||||
|
|
||||||
|
; Typed variadic parameters
|
||||||
|
(parameters
|
||||||
|
(typed_parameter
|
||||||
|
(list_splat_pattern ; *args: type
|
||||||
|
(identifier) @variable.parameter)))
|
||||||
|
|
||||||
|
(parameters
|
||||||
|
(typed_parameter
|
||||||
|
(dictionary_splat_pattern ; *kwargs: type
|
||||||
|
(identifier) @variable.parameter)))
|
||||||
|
|
||||||
|
; Lambda parameters
|
||||||
|
(lambda_parameters
|
||||||
|
(list_splat_pattern
|
||||||
|
(identifier) @variable.parameter))
|
||||||
|
|
||||||
|
(lambda_parameters
|
||||||
|
(dictionary_splat_pattern
|
||||||
|
(identifier) @variable.parameter))
|
||||||
|
|
||||||
|
((identifier) @variable.builtin
|
||||||
|
(#eq? @variable.builtin "self"))
|
||||||
|
|
||||||
|
((identifier) @variable.builtin
|
||||||
|
(#eq? @variable.builtin "cls"))
|
||||||
|
|
||||||
; After @type.builtin bacause builtins (such as `type`) are valid as attribute name
|
; After @type.builtin bacause builtins (such as `type`) are valid as attribute name
|
||||||
((attribute
|
((attribute
|
||||||
attribute: (identifier) @variable.member)
|
attribute: (identifier) @variable.member)
|
||||||
|
|
|
||||||
|
|
@ -2,12 +2,15 @@ class Fields:
|
||||||
type: str
|
type: str
|
||||||
# ^^^^ @variable.member
|
# ^^^^ @variable.member
|
||||||
|
|
||||||
def __init__(self, fields: list[int]) -> None:
|
def __init__(self, type: str, fields: list[int]) -> None:
|
||||||
# ^^^ @type.builtin
|
# ^^^^ @variable.builtin
|
||||||
# ^^^^ @constant.builtin
|
# ^^^^ @variable.parameter
|
||||||
|
# ^^^^^^ @variable.parameter
|
||||||
|
# ^^^ @type.builtin
|
||||||
|
# ^^^^ @constant.builtin
|
||||||
self.fields = fields
|
self.fields = fields
|
||||||
# ^^^^^^ @variable.member
|
# ^^^^^^ @variable.member
|
||||||
self.type = "foo"
|
self.type = type # this cannot be highlighted correctly by Treesitter
|
||||||
# ^^^^ @variable.member
|
# ^^^^ @variable.member
|
||||||
self.__dunderfield__ = None
|
self.__dunderfield__ = None
|
||||||
# ^^^^^^^^^^^^^^^ @variable.member
|
# ^^^^^^^^^^^^^^^ @variable.member
|
||||||
|
|
@ -15,3 +18,7 @@ class Fields:
|
||||||
# ^^^^^^^^^^^ @variable.member
|
# ^^^^^^^^^^^ @variable.member
|
||||||
self.NOT_A_FIELD = "IM NOT A FIELD"
|
self.NOT_A_FIELD = "IM NOT A FIELD"
|
||||||
# ^^^^^^^^^^^ @constant
|
# ^^^^^^^^^^^ @constant
|
||||||
|
|
||||||
|
Fields(type="schema", fields=[0, 1])
|
||||||
|
# ^^^^ @variable.parameter
|
||||||
|
# ^^^^^^ @variable.parameter
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,11 @@ _ = func()
|
||||||
|
|
||||||
class Foo:
|
class Foo:
|
||||||
def method(self) -> None: ...
|
def method(self) -> None: ...
|
||||||
|
# ^^^^ @variable.builtin
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def clsmethod(cls) -> None: ...
|
||||||
|
# ^^^ @variable.builtin
|
||||||
|
|
||||||
Foo().method()
|
Foo().method()
|
||||||
# ^^^^^^ @function.method.call
|
# ^^^^^^ @function.method.call
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue