]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-36953: Delay removal of ABCs from collections. (GH-13409)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Wed, 9 Oct 2019 09:29:31 +0000 (02:29 -0700)
committerNed Deily <nad@python.org>
Mon, 14 Oct 2019 21:04:26 +0000 (17:04 -0400)
Bump the removal to 3.9, indicate collections.abc available since 3.3,
replace version-changed directive to deprecated-removed.

https://bugs.python.org/issue36953
(cherry picked from commit eea47e09394dfb64d3a59a601d947d25bb1bdc96)

Co-authored-by: Matthias Bussonnier <mbussonnier@ucmerced.edu>
Doc/library/collections.rst
Lib/collections/__init__.py
Misc/NEWS.d/next/Library/2019-05-20-08-54-41.bpo-36952.I_glok.rst [new file with mode: 0644]

index 9f47e8978da3527c0bac38a44d4dfec06708e389..e9dbd094e0a969a0ef1701a696bf0a1a3f5df8e5 100644 (file)
@@ -33,10 +33,10 @@ Python's general purpose built-in containers, :class:`dict`, :class:`list`,
 :class:`UserString`     wrapper around string objects for easier string subclassing
 =====================   ====================================================================
 
-.. versionchanged:: 3.3
+.. deprecated-removed:: 3.3 3.9
     Moved :ref:`collections-abstract-base-classes` to the :mod:`collections.abc` module.
     For backwards compatibility, they continue to be visible in this module through
-    Python 3.7.  Subsequently, they will be removed entirely.
+    Python 3.8.
 
 
 :class:`ChainMap` objects
index 7ff3c80a06a7e8aa38e27ad82dd750f2a7629717..d353ff2b6f127b7deff9370df7b81feb9eef9fff 100644 (file)
@@ -47,8 +47,8 @@ def __getattr__(name):
         obj = getattr(_collections_abc, name)
         import warnings
         warnings.warn("Using or importing the ABCs from 'collections' instead "
-                      "of from 'collections.abc' is deprecated"
-                      "and in 3.8 it will stop working",
+                      "of from 'collections.abc' is deprecated since Python 3.3,"
+                      "and in 3.9 it will stop working",
                       DeprecationWarning, stacklevel=2)
         globals()[name] = obj
         return obj
diff --git a/Misc/NEWS.d/next/Library/2019-05-20-08-54-41.bpo-36952.I_glok.rst b/Misc/NEWS.d/next/Library/2019-05-20-08-54-41.bpo-36952.I_glok.rst
new file mode 100644 (file)
index 0000000..eeb4fd7
--- /dev/null
@@ -0,0 +1,5 @@
+Starting with Python 3.3, importing ABCs from :mod:`collections` is
+deprecated, and import should be done from :mod:`collections.abc`. Still
+being able to import from :mod:`collections` was marked for removal in 3.8,
+but has been delayed to 3.9; documentation and ``DeprecationWarning``
+clarified.