Skip to content
Snippets Groups Projects
Commit 31fe4f1b authored by Bob Lantz's avatar Bob Lantz
Browse files

Fix pmonitor() to not return blank lines on EOF

fixes #109 (hopefully)
parent dcb3036b
No related branches found
No related tags found
No related merge requests found
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
from time import sleep from time import sleep
from resource import setrlimit, RLIMIT_NPROC, RLIMIT_NOFILE from resource import setrlimit, RLIMIT_NPROC, RLIMIT_NOFILE
from select import poll, POLLIN from select import poll, POLLIN, POLLHUP
from subprocess import call, check_call, Popen, PIPE, STDOUT from subprocess import call, check_call, Popen, PIPE, STDOUT
import re import re
from fcntl import fcntl, F_GETFL, F_SETFL from fcntl import fcntl, F_GETFL, F_SETFL
...@@ -326,27 +326,24 @@ def pmonitor(popens, timeoutms=500, readline=True, ...@@ -326,27 +326,24 @@ def pmonitor(popens, timeoutms=500, readline=True,
# Use non-blocking reads # Use non-blocking reads
flags = fcntl( fd, F_GETFL ) flags = fcntl( fd, F_GETFL )
fcntl( fd, F_SETFL, flags | O_NONBLOCK ) fcntl( fd, F_SETFL, flags | O_NONBLOCK )
while True: while popens:
fds = poller.poll( timeoutms ) fds = poller.poll( timeoutms )
if fds: if fds:
for fd, _event in fds: for fd, event in fds:
host = fdToHost[ fd ] host = fdToHost[ fd ]
popen = popens[ host ] popen = popens[ host ]
if readline: if event & POLLIN:
# Attempt to read a line of output if readline:
# This blocks until we receive a newline! # Attempt to read a line of output
line = popen.stdout.readline() # This blocks until we receive a newline!
else: line = popen.stdout.readline()
line = popen.stdout.read( readmax ) else:
yield host, line line = popen.stdout.read( readmax )
yield host, line
# Check for EOF # Check for EOF
if not line: elif event & POLLHUP:
popen.poll() poller.unregister( fd )
if popen.returncode is not None: del popens[ host ]
poller.unregister( fd )
del popens[ host ]
if not popens:
return
else: else:
yield None, '' yield None, ''
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment