Commit be372d26 authored by Jason Madden's avatar Jason Madden

More safely handle getting a callback from libuv once we're destroyed.

parent 619e3d5f
...@@ -10,6 +10,9 @@ from collections import namedtuple ...@@ -10,6 +10,9 @@ from collections import namedtuple
from operator import delitem from operator import delitem
import signal import signal
from gevent import getcurrent
from gevent.exceptions import LoopExit
from gevent._ffi import _dbg # pylint: disable=unused-import from gevent._ffi import _dbg # pylint: disable=unused-import
from gevent._ffi.loop import AbstractLoop from gevent._ffi.loop import AbstractLoop
from gevent._ffi.loop import assign_standard_callbacks from gevent._ffi.loop import assign_standard_callbacks
...@@ -187,6 +190,14 @@ class loop(AbstractLoop): ...@@ -187,6 +190,14 @@ class loop(AbstractLoop):
libuv.uv_unref(self._signal_idle) libuv.uv_unref(self._signal_idle)
def _run_callbacks(self): def _run_callbacks(self):
if not self.ptr:
# We've been destroyed during the middle of self.run().
# This method is being called into from C, and it's not
# safe to go back to C (Windows in particular can abort
# the process with "GetQueuedCompletionStatusEx: (6) The
# handle is invalid.") So switch to the parent greenlet.
getcurrent().parent.throw(LoopExit('Destroyed during run'))
# Manually handle fork watchers. # Manually handle fork watchers.
curpid = os.getpid() curpid = os.getpid()
if curpid != self._pid: if curpid != self._pid:
......
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