mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 07:31:38 +00:00 
			
		
		
		
	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
		
	
	
	
		
			659 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
	
		
			659 B
		
	
	
	
		
			Python
		
	
	
	
	
	
import dataclasses
 | 
						|
import typing
 | 
						|
 | 
						|
T_CV2 = typing.ClassVar[int]
 | 
						|
T_CV3 = typing.ClassVar
 | 
						|
 | 
						|
T_IV2 = dataclasses.InitVar[int]
 | 
						|
T_IV3 = dataclasses.InitVar
 | 
						|
 | 
						|
@dataclasses.dataclass
 | 
						|
class CV:
 | 
						|
    T_CV4 = typing.ClassVar
 | 
						|
    cv0: typing.ClassVar[int] = 20
 | 
						|
    cv1: typing.ClassVar = 30
 | 
						|
    cv2: T_CV2
 | 
						|
    cv3: T_CV3
 | 
						|
    not_cv4: T_CV4  # When using string annotations, this field is not recognized as a ClassVar.
 | 
						|
 | 
						|
@dataclasses.dataclass
 | 
						|
class IV:
 | 
						|
    T_IV4 = dataclasses.InitVar
 | 
						|
    iv0: dataclasses.InitVar[int]
 | 
						|
    iv1: dataclasses.InitVar
 | 
						|
    iv2: T_IV2
 | 
						|
    iv3: T_IV3
 | 
						|
    not_iv4: T_IV4  # When using string annotations, this field is not recognized as an InitVar.
 |