Commit dca5780c authored by Jason Madden's avatar Jason Madden

Allow all keyword arguments to Popen under Python 2.

And make restore_signals default to False on Python 2.

Fixes #1063.
parent 099b997c
...@@ -4,10 +4,24 @@ ...@@ -4,10 +4,24 @@
.. currentmodule:: gevent .. currentmodule:: gevent
1.3.0 (unreleased) 1.3a2 (unreleased)
================== ==================
- Nothing changed yet. - Fix building from a source distribution without Cython installed.
- Make :class:`gevnt.subprocess.Popen` accept the ``restore_signals``
keyword argument on all versions of Python, and on Python 2 have it
default to false. It previously defaulted to true on all versions;
now it only defaults to true on Python 3. The standard library in
Python 2 does not have this argument and its behaviour with regards
to signals is undocumented, but there is code known to rely on
signals not being restored under Python 2. Initial report and patch
in :pr:`1063` by Florian Margaine.
- Allow :class:`gevent.subprocess.Popen` to accept the keyword
arguments ``pass_fds`` and ``start_new_session`` under Python 2.
They have always had the same default as Python 3, namely an empty
tuple and false, but now are accessible to Python 2.
1.3a1 (2018-01-27) 1.3a1 (2018-01-27)
......
...@@ -388,6 +388,9 @@ class Popen(object): ...@@ -388,6 +388,9 @@ class Popen(object):
Instances now save the ``args`` attribute under Python 2.7. Previously this was Instances now save the ``args`` attribute under Python 2.7. Previously this was
restricted to Python 3. restricted to Python 3.
.. versionchanged:: 1.2b1
Add the ``encoding`` and ``errors`` parameters for Python 3.
.. versionchanged:: 1.3a1 .. versionchanged:: 1.3a1
Accept "path-like" objects for the *cwd* parameter on all platforms. Accept "path-like" objects for the *cwd* parameter on all platforms.
This was added to Python 3.6. Previously with gevent, it only worked This was added to Python 3.6. Previously with gevent, it only worked
...@@ -396,48 +399,47 @@ class Popen(object): ...@@ -396,48 +399,47 @@ class Popen(object):
.. versionchanged:: 1.3a1 .. versionchanged:: 1.3a1
Add the ``text`` argument as a synonym for ``universal_newlines``, Add the ``text`` argument as a synonym for ``universal_newlines``,
as added on Python 3.7. as added on Python 3.7.
.. versionchanged:: 1.3a2
Allow the same keyword arguments under Python 2 as Python 3:
``pass_fds``, ``start_new_session``, ``restore_signals``, ``encoding``
and ``errors``. Under Python 2, ``encoding`` and ``errors`` are ignored
because native handling of universal newlines is used.
.. versionchanged:: 1.3a2
Under Python 2, ``restore_signals`` defaults to ``False``. Previously it
defaulted to ``True``, the same as it did in Python 3.
""" """
# The value returned from communicate() when there was nothing to read. # The value returned from communicate() when there was nothing to read.
# Changes if we're in text mode or universal newlines mode. # Changes if we're in text mode or universal newlines mode.
_communicate_empty_value = b'' _communicate_empty_value = b''
def __init__(self, args, bufsize=None, executable=None, def __init__(self, args,
bufsize=-1 if PY3 else 0,
executable=None,
stdin=None, stdout=None, stderr=None, stdin=None, stdout=None, stderr=None,
preexec_fn=None, close_fds=_PLATFORM_DEFAULT_CLOSE_FDS, shell=False, preexec_fn=None, close_fds=_PLATFORM_DEFAULT_CLOSE_FDS, shell=False,
cwd=None, env=None, universal_newlines=None, cwd=None, env=None, universal_newlines=None,
startupinfo=None, creationflags=0, threadpool=None, startupinfo=None, creationflags=0,
**kwargs): restore_signals=PY3, start_new_session=False,
"""Create new Popen instance. pass_fds=(),
:param kwargs: *Only* allowed under Python 3; under Python 2, any
unrecognized keyword arguments will result in a :exc:`TypeError`.
Under Python 3, keyword arguments can include ``pass_fds``, ``start_new_session``,
``restore_signals``, ``encoding`` and ``errors``
.. versionchanged:: 1.2b1
Add the ``encoding`` and ``errors`` parameters for Python 3.
"""
if not PY3 and kwargs:
raise TypeError("Got unexpected keyword arguments", kwargs)
pass_fds = kwargs.pop('pass_fds', ())
start_new_session = kwargs.pop('start_new_session', False)
restore_signals = kwargs.pop('restore_signals', True)
# Added in 3.6. These are kept as ivars # Added in 3.6. These are kept as ivars
encoding = self.encoding = kwargs.pop('encoding', None) encoding=None, errors=None,
errors = self.errors = kwargs.pop('errors', None) # Added in 3.7. Not an ivar directly.
# Added in 3.7. Not an ivar directly text=None,
text = kwargs.pop("text", None) # gevent additions
threadpool=None):
self.encoding = encoding
self.errors = errors
hub = get_hub() hub = get_hub()
if bufsize is None: if bufsize is None:
# bufsize has different defaults on Py3 and Py2 # Python 2 doesn't allow None at all, but Python 3 treats
if PY3: # it the same as the default. We do as well.
bufsize = -1 bufsize = -1 if PY3 else 0
else:
bufsize = 0
if not isinstance(bufsize, integer_types): if not isinstance(bufsize, integer_types):
raise TypeError("bufsize must be an integer") raise TypeError("bufsize must be an integer")
......
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