Commit 6da9a8b5 authored by Denis Bilenko's avatar Denis Bilenko

gevent.subprocess: fix gevent.wait([Popen]) on Windows

parent bb04dd39
...@@ -258,10 +258,6 @@ class Popen(object): ...@@ -258,10 +258,6 @@ class Popen(object):
def __repr__(self): def __repr__(self):
return '<%s at 0x%x pid=%r returncode=%r>' % (self.__class__.__name__, id(self), self.pid, self.returncode) return '<%s at 0x%x pid=%r returncode=%r>' % (self.__class__.__name__, id(self), self.pid, self.returncode)
def rawlink(self, callback):
self.result.rawlink(linkproxy(callback, self))
# XXX unlink
def _on_child(self, watcher): def _on_child(self, watcher):
watcher.stop() watcher.stop()
status = watcher.rstatus status = watcher.rstatus
...@@ -309,6 +305,10 @@ class Popen(object): ...@@ -309,6 +305,10 @@ class Popen(object):
def poll(self): def poll(self):
return self._internal_poll() return self._internal_poll()
def rawlink(self, callback):
self.result.rawlink(linkproxy(callback, self))
# XXX unlink
if mswindows: if mswindows:
# #
# Windows methods # Windows methods
...@@ -472,18 +472,31 @@ class Popen(object): ...@@ -472,18 +472,31 @@ class Popen(object):
if self.returncode is None: if self.returncode is None:
if WaitForSingleObject(self._handle, 0) == WAIT_OBJECT_0: if WaitForSingleObject(self._handle, 0) == WAIT_OBJECT_0:
self.returncode = GetExitCodeProcess(self._handle) self.returncode = GetExitCodeProcess(self._handle)
self.result.set(self.returncode)
return self.returncode return self.returncode
def _wait(self): def rawlink(self, callback):
if not self.result.ready() and not self._waiting:
self._waiting = True
Greenlet.spawn(self._wait)
self.result.rawlink(linkproxy(callback, self))
# XXX unlink
def _blocking_wait(self):
WaitForSingleObject(self._handle, INFINITE) WaitForSingleObject(self._handle, INFINITE)
return GetExitCodeProcess(self._handle) self.returncode = GetExitCodeProcess(self._handle)
return self.returncode
def _wait(self):
self.threadpool.spawn(self._blocking_wait).rawlink(self.result)
def wait(self, timeout=None): def wait(self, timeout=None):
"""Wait for child process to terminate. Returns returncode """Wait for child process to terminate. Returns returncode
attribute.""" attribute."""
if not self._waiting: if self.returncode is None:
self._waiting = True if not self._waiting:
self.threadpool.spawn(self._wait).rawlink(self.result) self._waiting = True
self._wait()
return self.result.wait(timeout=timeout) return self.result.wait(timeout=timeout)
def send_signal(self, sig): def send_signal(self, sig):
......
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