Commit 73a617e8 authored by Denis Bilenko's avatar Denis Bilenko

core: make loop class use set_syserr_cb to raise SystemError

parent 238ca31e
...@@ -3,6 +3,7 @@ cimport cython ...@@ -3,6 +3,7 @@ cimport cython
cimport libev cimport libev
from python cimport * from python cimport *
import sys import sys
import os
__all__ = ['get_version', __all__ = ['get_version',
...@@ -254,6 +255,8 @@ cdef public class loop [object PyGeventLoopObject, type PyGeventLoop_Type]: ...@@ -254,6 +255,8 @@ cdef public class loop [object PyGeventLoopObject, type PyGeventLoop_Type]:
self._ptr = libev.ev_loop_new(c_flags) self._ptr = libev.ev_loop_new(c_flags)
if not self._ptr: if not self._ptr:
raise SystemError("ev_loop_new(%s) failed" % (c_flags, )) raise SystemError("ev_loop_new(%s) failed" % (c_flags, ))
if default or __SYSERR_CALLBACK is None:
set_syserr_cb(self._handle_syserr)
cpdef _stop_signal_checker(self): cpdef _stop_signal_checker(self):
if libev.ev_is_active(&self._signal_checker): if libev.ev_is_active(&self._signal_checker):
...@@ -298,6 +301,9 @@ cdef public class loop [object PyGeventLoopObject, type PyGeventLoop_Type]: ...@@ -298,6 +301,9 @@ cdef public class loop [object PyGeventLoopObject, type PyGeventLoop_Type]:
def __get__(self): def __get__(self):
return libev.EV_MINPRI return libev.EV_MINPRI
def _handle_syserr(self, message, errno):
self.handle_error(None, SystemError, SystemError(message + ': ' + os.strerror(errno)), None)
cpdef handle_error(self, context, type, value, tb): cpdef handle_error(self, context, type, value, tb):
cdef object handle_error cdef object handle_error
cdef object error_handler = self.error_handler cdef object error_handler = self.error_handler
......
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