summaryrefslogtreecommitdiffstats
path: root/Lib/typing.py
diff options
context:
space:
mode:
authorTomas R <tomas.roun8@gmail.com>2023-05-25 20:14:58 (GMT)
committerGitHub <noreply@github.com>2023-05-25 20:14:58 (GMT)
commitfea8632ec69d160a11b8ec506900c14989952bc1 (patch)
tree856e592194ea9a7e46f98767999d2697c0534d3f /Lib/typing.py
parentd08679212d9af52dd074cd4a6abb440edb944c9c (diff)
downloadcpython-fea8632ec69d160a11b8ec506900c14989952bc1.zip
cpython-fea8632ec69d160a11b8ec506900c14989952bc1.tar.gz
cpython-fea8632ec69d160a11b8ec506900c14989952bc1.tar.bz2
gh-104786: Remove kwargs-based TypedDict creation (#104891)
Deprecated since Python 3.11. Co-authored-by: Alex Waygood <Alex.Waygood@Gmail.com>
Diffstat (limited to 'Lib/typing.py')
-rw-r--r--Lib/typing.py19
1 files changed, 2 insertions, 17 deletions
diff --git a/Lib/typing.py b/Lib/typing.py
index 85d129b..13f0883 100644
--- a/Lib/typing.py
+++ b/Lib/typing.py
@@ -29,7 +29,6 @@ import operator
import re as stdlib_re # Avoid confusion with the typing.re namespace on <=3.11
import sys
import types
-import warnings
from types import WrapperDescriptorType, MethodWrapperType, MethodDescriptorType, GenericAlias
from _typing import (
@@ -2822,7 +2821,7 @@ class _TypedDictMeta(type):
__instancecheck__ = __subclasscheck__
-def TypedDict(typename, fields=None, /, *, total=True, **kwargs):
+def TypedDict(typename, fields=None, /, *, total=True):
"""A simple typed namespace. At runtime it is equivalent to a plain dict.
TypedDict creates a dictionary type that expects all of its
@@ -2859,23 +2858,9 @@ def TypedDict(typename, fields=None, /, *, total=True, **kwargs):
checker is only expected to support a literal False or True as the value of
the total argument. True is the default, and makes all items defined in the
class body be required.
-
- The class syntax is only supported in Python 3.6+, while the other
- syntax form works for Python 2.7 and 3.2+
"""
if fields is None:
- fields = kwargs
- elif kwargs:
- raise TypeError("TypedDict takes either a dict or keyword arguments,"
- " but not both")
- if kwargs:
- warnings.warn(
- "The kwargs-based syntax for TypedDict definitions is deprecated "
- "in Python 3.11, will be removed in Python 3.13, and may not be "
- "understood by third-party type checkers.",
- DeprecationWarning,
- stacklevel=2,
- )
+ fields = {}
ns = {'__annotations__': dict(fields)}
module = _caller()