mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 10:26:02 +00:00 
			
		
		
		
	 044a1048ca
			
		
	
	
		044a1048ca
		
			
		
	
	
	
	
		
			
			The hard part was making all the tests pass; there are some subtle issues here, because apparently the future import wasn't tested very thoroughly in previous Python versions. For example, `inspect.signature()` returned type objects normally (except for forward references), but strings with the future import. We changed it to try and return type objects by calling `typing.get_type_hints()`, but fall back on returning strings if that function fails (which it may do if there are future references in the annotations that require passing in a specific namespace to resolve).
		
			
				
	
	
		
			26 lines
		
	
	
	
		
			578 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
	
		
			578 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| from dataclasses import dataclass, InitVar
 | |
| from typing import ClassVar
 | |
| 
 | |
| T_CV2 = ClassVar[int]
 | |
| T_CV3 = ClassVar
 | |
| 
 | |
| T_IV2 = InitVar[int]
 | |
| T_IV3 = InitVar
 | |
| 
 | |
| @dataclass
 | |
| class CV:
 | |
|     T_CV4 = ClassVar
 | |
|     cv0: ClassVar[int] = 20
 | |
|     cv1: ClassVar = 30
 | |
|     cv2: T_CV2
 | |
|     cv3: T_CV3
 | |
|     not_cv4: T_CV4  # When using string annotations, this field is not recognized as a ClassVar.
 | |
| 
 | |
| @dataclass
 | |
| class IV:
 | |
|     T_IV4 = InitVar
 | |
|     iv0: InitVar[int]
 | |
|     iv1: InitVar
 | |
|     iv2: T_IV2
 | |
|     iv3: T_IV3
 | |
|     not_iv4: T_IV4  # When using string annotations, this field is not recognized as an InitVar.
 |