Eryk Sun <eryk...@gmail.com> added the comment:

> my subrocess code doesn't seem to hang on Linux where the 
> thread example code does?

Reader threads for stdout and stderr are only used in Windows, since there's no 
equivalent to select/poll for synchronous pipes in Windows. 

Without using threads, I/O with synchronous pipes requires a busy loop. It has 
to poll PeekNamedPipe() to get the number of bytes available to read without 
blocking. For stdin, on the other hand, the Windows API does not allow getting 
the WriteQuotaAvailable from the PipeLocalInformation [1]. Without knowing how 
much can be written without blocking, the input pipe would have to be made 
non-blocking, which in turn requires an inner loop that tries to write a 
successively smaller chunk size to stdin until either it succeeds or the size 
is reduced to 0. 

If we wanted to change communicate() in Windows to not use threads and not 
require a busy loop, we'd have to switch to using named pipes opened in 
asynchronous (overlapped) mode on our side of each pipe. But that's an 
integration problem. For normal use as proc.stdout, etc, we would need an 
adapter or a new raw file type that implements a synchronous interface by 
waiting for I/O completion and maintaining its own file pointer. Such files 
would return the Windows file handle for fileno(), like sockets do, since a C 
file descriptor requires a synchronous-mode file.

---

[1] 
https://docs.microsoft.com/en-us/windows-hardware/drivers/ddi/ntifs/ns-ntifs-_file_pipe_local_information

----------

_______________________________________
Python tracker <rep...@bugs.python.org>
<https://bugs.python.org/issue43784>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to