Commit d911e40e authored by Ivan Levkivskyi's avatar Ivan Levkivskyi Committed by GitHub

bpo-32226: PEP 560: improve typing module (#4906)

This PR re-designs the internal typing API using the new PEP 560 features.
However, there are only few minor changes in the public API.
parent d57f26c7
...@@ -389,7 +389,8 @@ def _get_field(cls, a_name, a_type): ...@@ -389,7 +389,8 @@ def _get_field(cls, a_name, a_type):
if typing is not None: if typing is not None:
# This test uses a typing internal class, but it's the best # This test uses a typing internal class, but it's the best
# way to test if this is a ClassVar. # way to test if this is a ClassVar.
if type(a_type) is typing._ClassVar: if (type(a_type) is typing._GenericAlias and
a_type.__origin__ is typing.ClassVar):
# This field is a ClassVar, so it's not a field. # This field is a ClassVar, so it's not a field.
f._field_type = _FIELD_CLASSVAR f._field_type = _FIELD_CLASSVAR
......
...@@ -135,11 +135,6 @@ def dash_R_cleanup(fs, ps, pic, zdc, abcs): ...@@ -135,11 +135,6 @@ def dash_R_cleanup(fs, ps, pic, zdc, abcs):
# Clear ABC registries, restoring previously saved ABC registries. # Clear ABC registries, restoring previously saved ABC registries.
abs_classes = [getattr(collections.abc, a) for a in collections.abc.__all__] abs_classes = [getattr(collections.abc, a) for a in collections.abc.__all__]
abs_classes = filter(isabstract, abs_classes) abs_classes = filter(isabstract, abs_classes)
if 'typing' in sys.modules:
t = sys.modules['typing']
# These classes require special treatment because they do not appear
# in direct subclasses of collections.abc classes
abs_classes = list(abs_classes) + [t.ChainMap, t.Counter, t.DefaultDict]
for abc in abs_classes: for abc in abs_classes:
for obj in abc.__subclasses__() + [abc]: for obj in abc.__subclasses__() + [abc]:
obj._abc_registry = abcs.get(obj, WeakSet()).copy() obj._abc_registry = abcs.get(obj, WeakSet()).copy()
......
...@@ -827,7 +827,7 @@ class TestDescriptions(unittest.TestCase): ...@@ -827,7 +827,7 @@ class TestDescriptions(unittest.TestCase):
'f\x08fo\x08oo\x08o(data: List[Any], x: int)' 'f\x08fo\x08oo\x08o(data: List[Any], x: int)'
' -> Iterator[Tuple[int, Any]]') ' -> Iterator[Tuple[int, Any]]')
self.assertEqual(pydoc.render_doc(C).splitlines()[2], self.assertEqual(pydoc.render_doc(C).splitlines()[2],
'class C\x08C(typing.Mapping)') 'class C\x08C(collections.abc.Mapping, typing.Generic)')
def test_builtin(self): def test_builtin(self):
for name in ('str', 'str.translate', 'builtins.str', for name in ('str', 'str.translate', 'builtins.str',
......
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment