mirror of
https://github.com/python/cpython.git
synced 2025-07-19 17:25:54 +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.
|