Mercurial > public > mercurial-scm > hg
diff mercurial/windows.py @ 22245:234e4c24b980
platform: implement readpipe()
Reading all available data from a pipe has a platform-dependent
implementation.
This patch establishes platform.readpipe() by copying the
inline implementation in sshpeer.readerr(). The implementations
for POSIX and Windows are currently identical. The POSIX
implementation will be changed in a subsequent patch.
author | Gregory Szorc <gregory.szorc@gmail.com> |
---|---|
date | Fri, 15 Aug 2014 20:02:18 -0700 |
parents | a6014018ec28 |
children | 1642eb429536 |
line wrap: on
line diff
--- a/mercurial/windows.py Fri Aug 15 19:18:21 2014 -0700 +++ b/mercurial/windows.py Fri Aug 15 20:02:18 2014 -0700 @@ -336,3 +336,18 @@ def statisexec(st): '''check whether a stat result is an executable file''' return False + +def readpipe(pipe): + """Read all available data from a pipe.""" + chunks = [] + while True: + size = os.fstat(pipe.fileno()).st_size + if not size: + break + + s = pipe.read(size) + if not s: + break + chunks.append(s) + + return ''.join(chunks)