mirror of
				https://github.com/astral-sh/ruff.git
				synced 2025-10-25 09:28:14 +00:00 
			
		
		
		
	[ty] Add backreferences to TypedDict items in diagnostics (#20262)
## Summary Add backreferences to the original item declaration in TypedDict diagnostics. Thanks to @AlexWaygood for the suggestion. ## Test Plan Updated snapshots
This commit is contained in:
		
							parent
							
								
									9e45bfa9fd
								
							
						
					
					
						commit
						8ade6c4eaf
					
				
					 7 changed files with 146 additions and 149 deletions
				
			
		
							
								
								
									
										128
									
								
								crates/ty/docs/rules.md
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										128
									
								
								crates/ty/docs/rules.md
									
										
									
										generated
									
									
									
								
							|  | @ -36,7 +36,7 @@ def test(): -> "int": | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20call-non-callable) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L114) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L113) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -58,7 +58,7 @@ Calling a non-callable object will raise a `TypeError` at runtime. | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20conflicting-argument-forms) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L158) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L157) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -88,7 +88,7 @@ f(int)  # error | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20conflicting-declarations) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L184) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L183) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -117,7 +117,7 @@ a = 1 | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20conflicting-metaclass) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L209) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L208) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -147,7 +147,7 @@ class C(A, B): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20cyclic-class-definition) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L235) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L234) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -177,7 +177,7 @@ class B(A): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20duplicate-base) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L300) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L299) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -202,7 +202,7 @@ class B(A, A): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20duplicate-kw-only) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L321) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L320) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -306,7 +306,7 @@ def test(): -> "Literal[5]": | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20inconsistent-mro) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L524) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L523) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -334,7 +334,7 @@ class C(A, B): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20index-out-of-bounds) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L548) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L547) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -358,7 +358,7 @@ t[3]  # IndexError: tuple index out of range | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20instance-layout-conflict) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L353) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L352) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -445,7 +445,7 @@ an atypical memory layout. | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-argument-type) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L593) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L592) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -470,7 +470,7 @@ func("foo")  # error: [invalid-argument-type] | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-assignment) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L633) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L632) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -496,7 +496,7 @@ a: int = '' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-attribute-access) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1667) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1666) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -528,7 +528,7 @@ C.instance_var = 3  # error: Cannot assign to instance variable | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-await) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L655) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L654) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -562,7 +562,7 @@ asyncio.run(main()) | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-base) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L685) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L684) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -584,7 +584,7 @@ class A(42): ...  # error: [invalid-base] | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-context-manager) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L736) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L735) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -609,7 +609,7 @@ with 1: | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-declaration) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L757) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L756) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -636,7 +636,7 @@ a: str | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-exception-caught) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L780) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L779) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -678,7 +678,7 @@ except ZeroDivisionError: | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-generic-class) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L816) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L815) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -709,7 +709,7 @@ class C[U](Generic[T]): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-key) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L568) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L567) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -738,7 +738,7 @@ alice["height"]  # KeyError: 'height' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-legacy-type-variable) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L842) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L841) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -771,7 +771,7 @@ def f(t: TypeVar("U")): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-metaclass) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L891) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L890) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -803,7 +803,7 @@ class B(metaclass=f): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-named-tuple) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L498) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L497) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -833,7 +833,7 @@ TypeError: can only inherit from a NamedTuple type and Generic | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-overload) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L918) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L917) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -881,7 +881,7 @@ def foo(x: int) -> int: ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-parameter-default) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L961) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L960) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -905,7 +905,7 @@ def f(a: int = ''): ... | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-protocol) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L435) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L434) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -937,7 +937,7 @@ TypeError: Protocols can only inherit from other protocols, got <class 'int'> | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-raise) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L981) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L980) | ||||
| </small> | ||||
| 
 | ||||
| Checks for `raise` statements that raise non-exceptions or use invalid | ||||
|  | @ -984,7 +984,7 @@ def g(): | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-return-type) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L614) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L613) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1007,7 +1007,7 @@ def func() -> int: | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-super-argument) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1024) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1023) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1061,7 +1061,7 @@ TODO #14889 | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-type-alias-type) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L870) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L869) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1086,7 +1086,7 @@ NewAlias = TypeAliasType(get_name(), int)        # error: TypeAliasType name mus | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-type-checking-constant) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1063) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1062) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1114,7 +1114,7 @@ TYPE_CHECKING = '' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-type-form) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1087) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1086) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1142,7 +1142,7 @@ b: Annotated[int]  # `Annotated` expects at least two arguments | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-type-guard-call) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1139) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1138) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1174,7 +1174,7 @@ f(10)  # Error | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-type-guard-definition) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1111) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1110) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1206,7 +1206,7 @@ class C: | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20invalid-type-variable-constraints) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1167) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1166) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1239,7 +1239,7 @@ T = TypeVar('T', bound=str)  # valid bound TypeVar | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20missing-argument) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1196) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1195) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1262,7 +1262,7 @@ func()  # TypeError: func() missing 1 required positional argument: 'x' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20missing-typed-dict-key) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1766) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1765) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1293,7 +1293,7 @@ alice["age"]  # KeyError | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20no-matching-overload) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1215) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1214) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1320,7 +1320,7 @@ func("string")  # error: [no-matching-overload] | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20non-subscriptable) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1238) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1237) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1342,7 +1342,7 @@ Subscripting an object that does not support it will raise a `TypeError` at runt | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20not-iterable) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1256) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1255) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1366,7 +1366,7 @@ for i in 34:  # TypeError: 'int' object is not iterable | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20parameter-already-assigned) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1307) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1306) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1420,7 +1420,7 @@ def test(): -> "int": | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20static-assert-error) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1643) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1642) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1448,7 +1448,7 @@ static_assert(int(2.0 * 3.0) == 6)  # error: does not have a statically known tr | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20subclass-of-final-class) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1398) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1397) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1475,7 +1475,7 @@ class B(A): ...  # Error raised here | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20too-many-positional-arguments) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1443) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1442) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1500,7 +1500,7 @@ f("foo")  # Error raised here | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20type-assertion-failure) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1421) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1420) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1526,7 +1526,7 @@ def _(x: int): | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unavailable-implicit-super-arguments) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1464) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1463) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1570,7 +1570,7 @@ class A: | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unknown-argument) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1521) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1520) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1595,7 +1595,7 @@ f(x=1, y=2)  # Error raised here | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unresolved-attribute) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1542) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1541) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1621,7 +1621,7 @@ A().foo  # AttributeError: 'A' object has no attribute 'foo' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unresolved-import) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1564) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1563) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1644,7 +1644,7 @@ import foo  # ModuleNotFoundError: No module named 'foo' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unresolved-reference) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1583) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1582) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1667,7 +1667,7 @@ print(x)  # NameError: name 'x' is not defined | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unsupported-bool-conversion) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1276) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1275) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1702,7 +1702,7 @@ b1 < b2 < b1  # exception raised here | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unsupported-operator) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1602) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1601) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1728,7 +1728,7 @@ A() + A()  # TypeError: unsupported operand type(s) for +: 'A' and 'A' | |||
| <small> | ||||
| Default level: [`error`](../rules.md#rule-levels "This lint has a default level of 'error'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20zero-stepsize-in-slice) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1624) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1623) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1751,7 +1751,7 @@ l[1:10:0]  # ValueError: slice step cannot be zero | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20ambiguous-protocol-member) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L463) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L462) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1790,7 +1790,7 @@ class SubProto(BaseProto, Protocol): | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20deprecated) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L279) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L278) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1843,7 +1843,7 @@ a = 20 / 0  # type: ignore | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20possibly-unbound-attribute) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1328) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1327) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1869,7 +1869,7 @@ A.c  # AttributeError: type object 'A' has no attribute 'c' | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20possibly-unbound-implicit-call) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L132) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L131) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1899,7 +1899,7 @@ A()[0]  # TypeError: 'A' object is not subscriptable | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20possibly-unbound-import) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1350) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1349) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1929,7 +1929,7 @@ from module import a  # ImportError: cannot import name 'a' from 'module' | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20redundant-cast) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1695) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1694) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -1954,7 +1954,7 @@ cast(int, f())  # Redundant | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20undefined-reveal) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1503) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1502) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -2005,7 +2005,7 @@ a = 20 / 0  # ty: ignore[division-by-zero] | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unresolved-global) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1716) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1715) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -2059,7 +2059,7 @@ def g(): | |||
| <small> | ||||
| Default level: [`warn`](../rules.md#rule-levels "This lint has a default level of 'warn'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20unsupported-base) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L703) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L702) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -2096,7 +2096,7 @@ class D(C): ...  # error: [unsupported-base] | |||
| <small> | ||||
| Default level: [`ignore`](../rules.md#rule-levels "This lint has a default level of 'ignore'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20division-by-zero) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L261) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L260) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  | @ -2118,7 +2118,7 @@ Dividing by zero raises a `ZeroDivisionError` at runtime. | |||
| <small> | ||||
| Default level: [`ignore`](../rules.md#rule-levels "This lint has a default level of 'ignore'.") · | ||||
| [Related issues](https://github.com/astral-sh/ty/issues?q=sort%3Aupdated-desc%20is%3Aissue%20is%3Aopen%20possibly-unresolved-reference) · | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1376) | ||||
| [View source](https://github.com/astral-sh/ruff/blob/main/crates%2Fty_python_semantic%2Fsrc%2Ftypes%2Fdiagnostic.rs#L1375) | ||||
| </small> | ||||
| 
 | ||||
| **What it does** | ||||
|  |  | |||
|  | @ -108,6 +108,16 @@ error[invalid-assignment]: Invalid assignment to key "age" with declared type `i | |||
| 20 | | ||||
| 21 | def write_to_non_existing_key(person: Person): | ||||
|    | | ||||
| info: Item declaration | ||||
|  --> src/mdtest_snippet.py:5:5 | ||||
|   | | ||||
| 3 | class Person(TypedDict): | ||||
| 4 |     name: str | ||||
| 5 |     age: int | None | ||||
|   |     --------------- Item declared here | ||||
| 6 | | ||||
| 7 | def access_invalid_literal_string_key(person: Person): | ||||
|   | | ||||
| info: rule `invalid-assignment` is enabled by default | ||||
| 
 | ||||
| ``` | ||||
|  | @ -151,6 +161,14 @@ error[invalid-assignment]: Cannot assign to key "id" on TypedDict `Employee` | |||
|    |     | | ||||
|    |     TypedDict `Employee` | ||||
|    | | ||||
| info: Item declaration | ||||
|   --> src/mdtest_snippet.py:29:5 | ||||
|    | | ||||
| 28 | class Employee(TypedDict): | ||||
| 29 |     id: ReadOnly[int] | ||||
|    |     ----------------- Read-only item declared here | ||||
| 30 |     name: str | ||||
|    | | ||||
| info: rule `invalid-assignment` is enabled by default | ||||
| 
 | ||||
| ``` | ||||
|  |  | |||
|  | @ -486,6 +486,9 @@ type DeclaredTypeAndConflictingTypes<'db> = ( | |||
| pub(crate) struct PlaceFromDeclarationsResult<'db> { | ||||
|     place_and_quals: PlaceAndQualifiers<'db>, | ||||
|     conflicting_types: Option<Box<indexmap::set::Slice<Type<'db>>>>, | ||||
|     /// Contains `Some(declaration)` if the declared type originates from exactly one declaration.
 | ||||
|     /// This field is used for backreferences in diagnostics.
 | ||||
|     pub(crate) single_declaration: Option<Definition<'db>>, | ||||
| } | ||||
| 
 | ||||
| impl<'db> PlaceFromDeclarationsResult<'db> { | ||||
|  | @ -496,6 +499,7 @@ impl<'db> PlaceFromDeclarationsResult<'db> { | |||
|         PlaceFromDeclarationsResult { | ||||
|             place_and_quals, | ||||
|             conflicting_types: Some(conflicting_types), | ||||
|             single_declaration: None, | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -513,21 +517,6 @@ impl<'db> PlaceFromDeclarationsResult<'db> { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| impl<'db> From<PlaceAndQualifiers<'db>> for PlaceFromDeclarationsResult<'db> { | ||||
|     fn from(place_and_quals: PlaceAndQualifiers<'db>) -> Self { | ||||
|         PlaceFromDeclarationsResult { | ||||
|             place_and_quals, | ||||
|             conflicting_types: None, | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl<'db> From<Place<'db>> for PlaceFromDeclarationsResult<'db> { | ||||
|     fn from(place: Place<'db>) -> Self { | ||||
|         PlaceFromDeclarationsResult::from(PlaceAndQualifiers::from(place)) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| /// A type with declaredness information, and a set of type qualifiers.
 | ||||
| ///
 | ||||
| /// This is used to represent the result of looking up the declared type. Consider this
 | ||||
|  | @ -1216,6 +1205,8 @@ fn place_from_declarations_impl<'db>( | |||
|     let reachability_constraints = declarations.reachability_constraints; | ||||
|     let boundness_analysis = declarations.boundness_analysis; | ||||
|     let mut declarations = declarations.peekable(); | ||||
|     let mut first_declaration = None; | ||||
|     let mut exactly_one_declaration = false; | ||||
| 
 | ||||
|     let is_non_exported = |declaration: Definition<'db>| { | ||||
|         requires_explicit_reexport.is_yes() && !is_reexported(db, declaration) | ||||
|  | @ -1246,6 +1237,13 @@ fn place_from_declarations_impl<'db>( | |||
|                 return None; | ||||
|             } | ||||
| 
 | ||||
|             if first_declaration.is_none() { | ||||
|                 first_declaration = Some(declaration); | ||||
|                 exactly_one_declaration = true; | ||||
|             } else { | ||||
|                 exactly_one_declaration = false; | ||||
|             } | ||||
| 
 | ||||
|             let static_reachability = | ||||
|                 reachability_constraints.evaluate(db, predicates, reachability_constraint); | ||||
| 
 | ||||
|  | @ -1302,10 +1300,18 @@ fn place_from_declarations_impl<'db>( | |||
|         if let Some(conflicting) = conflicting { | ||||
|             PlaceFromDeclarationsResult::conflict(place_and_quals, conflicting) | ||||
|         } else { | ||||
|             place_and_quals.into() | ||||
|             PlaceFromDeclarationsResult { | ||||
|                 place_and_quals, | ||||
|                 conflicting_types: None, | ||||
|                 single_declaration: first_declaration.filter(|_| exactly_one_declaration), | ||||
|             } | ||||
|         } | ||||
|     } else { | ||||
|         Place::Unbound.into() | ||||
|         PlaceFromDeclarationsResult { | ||||
|             place_and_quals: Place::Unbound.into(), | ||||
|             conflicting_types: None, | ||||
|             single_declaration: None, | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -9,12 +9,10 @@ use super::{ | |||
| use crate::FxOrderMap; | ||||
| use crate::module_resolver::KnownModule; | ||||
| use crate::semantic_index::definition::{Definition, DefinitionState}; | ||||
| use crate::semantic_index::place::ScopedPlaceId; | ||||
| use crate::semantic_index::scope::NodeWithScopeKind; | ||||
| use crate::semantic_index::symbol::Symbol; | ||||
| use crate::semantic_index::{ | ||||
|     BindingWithConstraints, DeclarationWithConstraint, SemanticIndex, attribute_declarations, | ||||
|     attribute_scopes, | ||||
|     DeclarationWithConstraint, SemanticIndex, attribute_declarations, attribute_scopes, | ||||
| }; | ||||
| use crate::types::constraints::{ConstraintSet, Constraints, IteratorConstraintsExtension}; | ||||
| use crate::types::context::InferContext; | ||||
|  | @ -1283,6 +1281,9 @@ pub(crate) struct Field<'db> { | |||
|     pub(crate) declared_ty: Type<'db>, | ||||
|     /// Kind-specific metadata for this field
 | ||||
|     pub(crate) kind: FieldKind<'db>, | ||||
|     /// The original declaration of this field, if there is exactly one.
 | ||||
|     /// This field is used for backreferences in diagnostics.
 | ||||
|     pub(crate) single_declaration: Option<Definition<'db>>, | ||||
| } | ||||
| 
 | ||||
| impl Field<'_> { | ||||
|  | @ -2666,7 +2667,9 @@ impl<'db> ClassLiteral<'db> { | |||
| 
 | ||||
|             let symbol = table.symbol(symbol_id); | ||||
| 
 | ||||
|             let attr = place_from_declarations(db, declarations).ignore_conflicting_declarations(); | ||||
|             let result = place_from_declarations(db, declarations.clone()); | ||||
|             let single_declaration = result.single_declaration; | ||||
|             let attr = result.ignore_conflicting_declarations(); | ||||
|             if attr.is_class_var() { | ||||
|                 continue; | ||||
|             } | ||||
|  | @ -2728,6 +2731,7 @@ impl<'db> ClassLiteral<'db> { | |||
|                 let mut field = Field { | ||||
|                     declared_ty: attr_ty.apply_optional_specialization(db, specialization), | ||||
|                     kind, | ||||
|                     single_declaration, | ||||
|                 }; | ||||
| 
 | ||||
|                 // Check if this is a KW_ONLY sentinel and mark subsequent fields as keyword-only
 | ||||
|  | @ -3330,54 +3334,6 @@ impl<'db> ClassLiteral<'db> { | |||
|                 .unwrap_or_else(|| class_name.end()), | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|     pub(super) fn declarations_of_name( | ||||
|         self, | ||||
|         db: &'db dyn Db, | ||||
|         name: &str, | ||||
|         index: &'db SemanticIndex<'db>, | ||||
|     ) -> Option<impl Iterator<Item = DeclarationWithConstraint<'db>>> { | ||||
|         let class_body_scope = self.body_scope(db).file_scope_id(db); | ||||
|         let symbol_id = index.place_table(class_body_scope).symbol_id(name)?; | ||||
|         let use_def = index.use_def_map(class_body_scope); | ||||
|         Some(use_def.end_of_scope_declarations(ScopedPlaceId::Symbol(symbol_id))) | ||||
|     } | ||||
| 
 | ||||
|     pub(super) fn first_declaration_of_name( | ||||
|         self, | ||||
|         db: &'db dyn Db, | ||||
|         name: &str, | ||||
|         index: &'db SemanticIndex<'db>, | ||||
|     ) -> Option<DeclarationWithConstraint<'db>> { | ||||
|         self.declarations_of_name(db, name, index) | ||||
|             .into_iter() | ||||
|             .flatten() | ||||
|             .next() | ||||
|     } | ||||
| 
 | ||||
|     pub(super) fn bindings_of_name( | ||||
|         self, | ||||
|         db: &'db dyn Db, | ||||
|         name: &str, | ||||
|         index: &'db SemanticIndex<'db>, | ||||
|     ) -> Option<impl Iterator<Item = BindingWithConstraints<'db, 'db>>> { | ||||
|         let class_body_scope = self.body_scope(db).file_scope_id(db); | ||||
|         let symbol_id = index.place_table(class_body_scope).symbol_id(name)?; | ||||
|         let use_def = index.use_def_map(class_body_scope); | ||||
|         Some(use_def.end_of_scope_bindings(ScopedPlaceId::Symbol(symbol_id))) | ||||
|     } | ||||
| 
 | ||||
|     pub(super) fn first_binding_of_name( | ||||
|         self, | ||||
|         db: &'db dyn Db, | ||||
|         name: &str, | ||||
|         index: &'db SemanticIndex<'db>, | ||||
|     ) -> Option<BindingWithConstraints<'db, 'db>> { | ||||
|         self.bindings_of_name(db, name, index) | ||||
|             .into_iter() | ||||
|             .flatten() | ||||
|             .next() | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl<'db> From<ClassLiteral<'db>> for Type<'db> { | ||||
|  |  | |||
|  | @ -6,7 +6,6 @@ use super::{ | |||
|     add_inferred_python_version_hint_to_diagnostic, | ||||
| }; | ||||
| use crate::lint::{Level, LintRegistryBuilder, LintStatus}; | ||||
| use crate::semantic_index::SemanticIndex; | ||||
| use crate::semantic_index::definition::Definition; | ||||
| use crate::semantic_index::place::{PlaceTable, ScopedPlaceId}; | ||||
| use crate::suppression::FileSuppressionId; | ||||
|  | @ -2887,16 +2886,13 @@ pub(crate) fn report_invalid_key_on_typed_dict<'db>( | |||
| pub(super) fn report_namedtuple_field_without_default_after_field_with_default<'db>( | ||||
|     context: &InferContext<'db, '_>, | ||||
|     class: ClassLiteral<'db>, | ||||
|     index: &'db SemanticIndex<'db>, | ||||
|     field_name: &str, | ||||
|     field_with_default: &str, | ||||
|     (field, field_def): &(Name, Option<Definition<'db>>), | ||||
|     (field_with_default, field_with_default_def): &(Name, Option<Definition<'db>>), | ||||
| ) { | ||||
|     let db = context.db(); | ||||
|     let module = context.module(); | ||||
| 
 | ||||
|     let diagnostic_range = class | ||||
|         .first_declaration_of_name(db, field_name, index) | ||||
|         .and_then(|definition| definition.declaration.definition()) | ||||
|     let diagnostic_range = field_def | ||||
|         .map(|definition| definition.kind(db).full_range(module)) | ||||
|         .unwrap_or_else(|| class.header_range(db)); | ||||
| 
 | ||||
|  | @ -2908,13 +2904,11 @@ pub(super) fn report_namedtuple_field_without_default_after_field_with_default<' | |||
|     )); | ||||
| 
 | ||||
|     diagnostic.set_primary_message(format_args!( | ||||
|         "Field `{field_name}` defined here without a default value" | ||||
|         "Field `{field}` defined here without a default value", | ||||
|     )); | ||||
| 
 | ||||
|     let Some(field_with_default_range) = class | ||||
|         .first_binding_of_name(db, field_with_default, index) | ||||
|         .and_then(|definition| definition.binding.definition()) | ||||
|         .map(|definition| definition.kind(db).full_range(module)) | ||||
|     let Some(field_with_default_range) = | ||||
|         field_with_default_def.map(|definition| definition.kind(db).full_range(module)) | ||||
|     else { | ||||
|         return; | ||||
|     }; | ||||
|  | @ -2933,7 +2927,7 @@ pub(super) fn report_namedtuple_field_without_default_after_field_with_default<' | |||
|         ); | ||||
|     } else { | ||||
|         diagnostic.info(format_args!( | ||||
|             "Earlier field `{field_with_default}` was defined with a default value" | ||||
|             "Earlier field `{field_with_default}` was defined with a default value", | ||||
|         )); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1191,14 +1191,14 @@ impl<'db, 'ast> TypeInferenceBuilder<'db, 'ast> { | |||
|                             default_ty: Some(_) | ||||
|                         } | ||||
|                     ) { | ||||
|                         field_with_default_encountered = Some(field_name); | ||||
|                         field_with_default_encountered = | ||||
|                             Some((field_name, field.single_declaration)); | ||||
|                     } else if let Some(field_with_default) = field_with_default_encountered.as_ref() | ||||
|                     { | ||||
|                         report_namedtuple_field_without_default_after_field_with_default( | ||||
|                             &self.context, | ||||
|                             class, | ||||
|                             self.index, | ||||
|                             &field_name, | ||||
|                             &(field_name, field.single_declaration), | ||||
|                             field_with_default, | ||||
|                         ); | ||||
|                     } | ||||
|  |  | |||
|  | @ -1,6 +1,9 @@ | |||
| use bitflags::bitflags; | ||||
| use ruff_db::diagnostic::{Annotation, Diagnostic, Span, SubDiagnostic, SubDiagnosticSeverity}; | ||||
| use ruff_db::parsed::parsed_module; | ||||
| use ruff_python_ast::Arguments; | ||||
| use ruff_python_ast::{self as ast, AnyNodeRef, StmtClassDef, name::Name}; | ||||
| use ruff_text_size::Ranged; | ||||
| 
 | ||||
| use super::class::{ClassType, CodeGeneratorKind, Field}; | ||||
| use super::context::InferContext; | ||||
|  | @ -157,6 +160,22 @@ pub(super) fn validate_typed_dict_key_assignment<'db, 'ast>( | |||
|         return false; | ||||
|     }; | ||||
| 
 | ||||
|     let add_item_definition_subdiagnostic = |diagnostic: &mut Diagnostic, message| { | ||||
|         if let Some(declaration) = item.single_declaration { | ||||
|             let file = declaration.file(db); | ||||
|             let module = parsed_module(db, file).load(db); | ||||
| 
 | ||||
|             let mut sub = SubDiagnostic::new(SubDiagnosticSeverity::Info, "Item declaration"); | ||||
|             sub.annotate( | ||||
|                 Annotation::secondary( | ||||
|                     Span::from(file).with_range(declaration.full_range(db, &module).range()), | ||||
|                 ) | ||||
|                 .message(message), | ||||
|             ); | ||||
|             diagnostic.sub(sub); | ||||
|         } | ||||
|     }; | ||||
| 
 | ||||
|     if assignment_kind.is_subscript() && item.is_read_only() { | ||||
|         if let Some(builder) = | ||||
|             context.report_lint(assignment_kind.diagnostic_type(), key_node.into()) | ||||
|  | @ -175,6 +194,8 @@ pub(super) fn validate_typed_dict_key_assignment<'db, 'ast>( | |||
|                     .secondary(typed_dict_node.into()) | ||||
|                     .message(format_args!("TypedDict `{typed_dict_d}`")), | ||||
|             ); | ||||
| 
 | ||||
|             add_item_definition_subdiagnostic(&mut diagnostic, "Read-only item declared here"); | ||||
|         } | ||||
| 
 | ||||
|         return false; | ||||
|  | @ -211,6 +232,8 @@ pub(super) fn validate_typed_dict_key_assignment<'db, 'ast>( | |||
|                 .secondary(key_node.into()) | ||||
|                 .message(format_args!("key has declared type `{item_type_d}`")), | ||||
|         ); | ||||
| 
 | ||||
|         add_item_definition_subdiagnostic(&mut diagnostic, "Item declared here"); | ||||
|     } | ||||
| 
 | ||||
|     false | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Peter
						David Peter