(and corresponding ``EXPERIMENTAL_ISOLATED_SUBINTERPRETERS``)
have been removed.
+* Remove ``io.OpenWrapper`` and ``_pyio.OpenWrapper``, deprecated in Python
+ 3.10: just use :func:`open` instead. The :func:`open` (:func:`io.open`)
+ function is a built-in function. Since Python 3.10, :func:`_pyio.open` is
+ also a static method.
+ (Contributed by Victor Stinner in :gh:`94169`.)
+
Porting to Python 3.12
======================
open_code = _open_code_with_warning
-def __getattr__(name):
- if name == "OpenWrapper":
- # bpo-43680: Until Python 3.9, _pyio.open was not a static method and
- # builtins.open was set to OpenWrapper to not become a bound method
- # when set to a class variable. _io.open is a built-in function whereas
- # _pyio.open is a Python function. In Python 3.10, _pyio.open() is now
- # a static method, and builtins.open() is now io.open().
- import warnings
- warnings.warn('OpenWrapper is deprecated, use open instead',
- DeprecationWarning, stacklevel=2)
- global OpenWrapper
- OpenWrapper = open
- return OpenWrapper
- raise AttributeError(f"module {__name__!r} has no attribute {name!r}")
-
-
# In normal operation, both `UnsupportedOperation`s should be bound to the
# same object.
try:
IncrementalNewlineDecoder, text_encoding, TextIOWrapper)
-def __getattr__(name):
- if name == "OpenWrapper":
- # bpo-43680: Until Python 3.9, _pyio.open was not a static method and
- # builtins.open was set to OpenWrapper to not become a bound method
- # when set to a class variable. _io.open is a built-in function whereas
- # _pyio.open is a Python function. In Python 3.10, _pyio.open() is now
- # a static method, and builtins.open() is now io.open().
- import warnings
- warnings.warn('OpenWrapper is deprecated, use open instead',
- DeprecationWarning, stacklevel=2)
- global OpenWrapper
- OpenWrapper = open
- return OpenWrapper
- raise AttributeError("module {__name__!r} has no attribute {name!r}")
-
-
# Pretend this exception was created here.
UnsupportedOperation.__module__ = "io"
proc = assert_python_ok('-X', 'utf8=1', '-c', code)
self.assertEqual(b"utf-8", proc.out.strip())
- @support.cpython_only
- # Depending if OpenWrapper was already created or not, the warning is
- # emitted or not. For example, the attribute is already created when this
- # test is run multiple times.
- @warnings_helper.ignore_warnings(category=DeprecationWarning)
- def test_openwrapper(self):
- self.assertIs(self.io.OpenWrapper, self.io.open)
-
class CMiscIOTest(MiscIOTest):
io = io
--- /dev/null
+Remove ``io.OpenWrapper`` and ``_pyio.OpenWrapper``, deprecated in Python
+3.10: just use :func:`open` instead. The :func:`open` (:func:`io.open`)
+function is a built-in function. Since Python 3.10, :func:`_pyio.open` is
+also a static method. Patch by Victor Stinner.