Kaydet (Commit) d4b645ef authored tarafından Gregory P. Smith's avatar Gregory P. Smith

Remove the subprocess "bad exception data" warning (formerly a print!)

all together and just include the repr of the data in the exception
itself instead of the useless string "Unknown".

This code path is unlikely to even be possible to take given the
nature of the pipe it gets subprocess data from.
...@@ -1412,11 +1412,10 @@ class Popen(object): ...@@ -1412,11 +1412,10 @@ class Popen(object):
exception_name, hex_errno, err_msg = ( exception_name, hex_errno, err_msg = (
errpipe_data.split(b':', 2)) errpipe_data.split(b':', 2))
except ValueError: except ValueError:
warnings.warn(RuntimeWarning(
'Bad exception data: %r' % errpipe_data))
exception_name = b'SubprocessError' exception_name = b'SubprocessError'
hex_errno = b'0' hex_errno = b'0'
err_msg = b'Unknown' err_msg = (b'Bad exception data from child: ' +
repr(errpipe_data))
child_exception_type = getattr( child_exception_type = getattr(
builtins, exception_name.decode('ascii'), builtins, exception_name.decode('ascii'),
SubprocessError) SubprocessError)
......
...@@ -116,6 +116,9 @@ Core and Builtins ...@@ -116,6 +116,9 @@ Core and Builtins
Library Library
------- -------
- Remove a bare print to stdout from the subprocess module that could have
happened if the child process wrote garbage to its pre-exec error pipe.
- The subprocess module now raises its own SubprocessError instead of a - The subprocess module now raises its own SubprocessError instead of a
RuntimeError in various error situations which should not normally happen. RuntimeError in various error situations which should not normally happen.
......
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