mirror of
https://github.com/python/cpython.git
synced 2025-09-30 20:31:52 +00:00
On Windows, subprocess.Popen.communicate() now also ignore EINVAL
on stdin.write() if the child process is still running but closed the
pipe.
(cherry picked from commit d52aa31378
)
This commit is contained in:
parent
31b950ab86
commit
b319d09ee4
2 changed files with 11 additions and 6 deletions
|
@ -776,19 +776,21 @@ class Popen(object):
|
|||
self.stdin.write(input)
|
||||
except BrokenPipeError:
|
||||
pass # communicate() must ignore broken pipe errors.
|
||||
except OSError as e:
|
||||
if e.errno == errno.EINVAL and self.poll() is not None:
|
||||
# Issue #19612: On Windows, stdin.write() fails with EINVAL
|
||||
# if the process already exited before the write
|
||||
except OSError as exc:
|
||||
if exc.errno == errno.EINVAL:
|
||||
# bpo-19612, bpo-30418: On Windows, stdin.write() fails
|
||||
# with EINVAL if the child process exited or if the child
|
||||
# process is still running but closed the pipe.
|
||||
pass
|
||||
else:
|
||||
raise
|
||||
|
||||
try:
|
||||
self.stdin.close()
|
||||
except BrokenPipeError:
|
||||
pass # communicate() must ignore broken pipe errors.
|
||||
except OSError as e:
|
||||
if e.errno == errno.EINVAL and self.poll() is not None:
|
||||
except OSError as exc:
|
||||
if exc.errno == errno.EINVAL:
|
||||
pass
|
||||
else:
|
||||
raise
|
||||
|
|
|
@ -45,6 +45,9 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- bpo-30418: On Windows, subprocess.Popen.communicate() now also ignore EINVAL
|
||||
on stdin.write() if the child process is still running but closed the pipe.
|
||||
|
||||
- bpo-29822: inspect.isabstract() now works during __init_subclass__. Patch
|
||||
by Nate Soares.
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue