mirror of https://github.com/python/cpython
merge from upstream
This commit is contained in:
commit
482e7e061b
|
@ -208,7 +208,7 @@ Windows Platform
|
||||||
Win95/98 specific
|
Win95/98 specific
|
||||||
^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
.. function:: popen(cmd, mode='r', bufsize=None)
|
.. function:: popen(cmd, mode='r', bufsize=-1)
|
||||||
|
|
||||||
Portable :func:`popen` interface. Find a working popen implementation
|
Portable :func:`popen` interface. Find a working popen implementation
|
||||||
preferring :func:`win32pipe.popen`. On Windows NT, :func:`win32pipe.popen`
|
preferring :func:`win32pipe.popen`. On Windows NT, :func:`win32pipe.popen`
|
||||||
|
|
|
@ -779,11 +779,13 @@ if not _exists("urandom"):
|
||||||
return bs
|
return bs
|
||||||
|
|
||||||
# Supply os.popen()
|
# Supply os.popen()
|
||||||
def popen(cmd, mode="r", buffering=None):
|
def popen(cmd, mode="r", buffering=-1):
|
||||||
if not isinstance(cmd, str):
|
if not isinstance(cmd, str):
|
||||||
raise TypeError("invalid cmd type (%s, expected string)" % type(cmd))
|
raise TypeError("invalid cmd type (%s, expected string)" % type(cmd))
|
||||||
if mode not in ("r", "w"):
|
if mode not in ("r", "w"):
|
||||||
raise ValueError("invalid mode %r" % mode)
|
raise ValueError("invalid mode %r" % mode)
|
||||||
|
if buffering == 0 or buffering == None:
|
||||||
|
raise ValueError("popen() does not support unbuffered streams")
|
||||||
import subprocess, io
|
import subprocess, io
|
||||||
if mode == "r":
|
if mode == "r":
|
||||||
proc = subprocess.Popen(cmd,
|
proc = subprocess.Popen(cmd,
|
||||||
|
|
|
@ -357,7 +357,7 @@ def dist(distname='',version='',id='',
|
||||||
supported_dists=supported_dists,
|
supported_dists=supported_dists,
|
||||||
full_distribution_name=0)
|
full_distribution_name=0)
|
||||||
|
|
||||||
def popen(cmd, mode='r', bufsize=None):
|
def popen(cmd, mode='r', bufsize=-1):
|
||||||
|
|
||||||
""" Portable popen() interface.
|
""" Portable popen() interface.
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -743,8 +743,6 @@ class Popen(object):
|
||||||
if errread != -1:
|
if errread != -1:
|
||||||
errread = msvcrt.open_osfhandle(errread.Detach(), 0)
|
errread = msvcrt.open_osfhandle(errread.Detach(), 0)
|
||||||
|
|
||||||
if bufsize == 0:
|
|
||||||
bufsize = 1 # Nearly unbuffered (XXX for now)
|
|
||||||
if p2cwrite != -1:
|
if p2cwrite != -1:
|
||||||
self.stdin = io.open(p2cwrite, 'wb', bufsize)
|
self.stdin = io.open(p2cwrite, 'wb', bufsize)
|
||||||
if self.universal_newlines:
|
if self.universal_newlines:
|
||||||
|
|
|
@ -1315,6 +1315,22 @@ class POSIXProcessTestCase(BaseTestCase):
|
||||||
" non-zero with this error:\n%s" %
|
" non-zero with this error:\n%s" %
|
||||||
stderr.decode('utf-8'))
|
stderr.decode('utf-8'))
|
||||||
|
|
||||||
|
def test_select_unbuffered(self):
|
||||||
|
# Issue #11459: bufsize=0 should really set the pipes as
|
||||||
|
# unbuffered (and therefore let select() work properly).
|
||||||
|
select = support.import_module("select")
|
||||||
|
p = subprocess.Popen([sys.executable, "-c",
|
||||||
|
'import sys;'
|
||||||
|
'sys.stdout.write("apple")'],
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
bufsize=0)
|
||||||
|
f = p.stdout
|
||||||
|
try:
|
||||||
|
self.assertEqual(f.read(4), b"appl")
|
||||||
|
self.assertIn(f, select.select([f], [], [], 0.0)[0])
|
||||||
|
finally:
|
||||||
|
p.wait()
|
||||||
|
|
||||||
|
|
||||||
@unittest.skipUnless(mswindows, "Windows specific tests")
|
@unittest.skipUnless(mswindows, "Windows specific tests")
|
||||||
class Win32ProcessTestCase(BaseTestCase):
|
class Win32ProcessTestCase(BaseTestCase):
|
||||||
|
|
|
@ -75,6 +75,9 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #11459: A ``bufsize`` value of 0 in subprocess.Popen() really creates
|
||||||
|
unbuffered pipes, such that select() works properly on them.
|
||||||
|
|
||||||
- Issue #5421: Fix misleading error message when one of socket.sendto()'s
|
- Issue #5421: Fix misleading error message when one of socket.sendto()'s
|
||||||
arguments has the wrong type. Patch by Nikita Vetoshkin.
|
arguments has the wrong type. Patch by Nikita Vetoshkin.
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue