Commit 9ae602e6 authored by Denis Bilenko's avatar Denis Bilenko

core.pyx: simplify getaddrinfo_request

parent ec2e21b0
...@@ -270,7 +270,7 @@ cdef class evdns_base: ...@@ -270,7 +270,7 @@ cdef class evdns_base:
Py_INCREF(param) Py_INCREF(param)
cdef void* c_request = levent.evdns_getaddrinfo(self._ptr, nodename, servname, &hints, __getaddrinfo_handler, <void*>param) cdef void* c_request = levent.evdns_getaddrinfo(self._ptr, nodename, servname, &hints, __getaddrinfo_handler, <void*>param)
if c_request: if c_request:
request = getaddrinfo_request(self.base, <size_t>c_request) request = getaddrinfo_request(<size_t>c_request)
param.append(request) param.append(request)
return request return request
...@@ -290,10 +290,12 @@ cdef void __getaddrinfo_handler(int code, levent.evutil_addrinfo* res, void* c_p ...@@ -290,10 +290,12 @@ cdef void __getaddrinfo_handler(int code, levent.evutil_addrinfo* res, void* c_p
else: else:
callback, arg, request = param callback, arg, request = param
if request is not None: if code == levent.EVUTIL_EAI_CANCEL:
if request.base is None: # cancelled? return
request.detach()
if request is not None and not request._ptr:
return return
request.detach() request.detach()
if code: if code:
...@@ -323,11 +325,9 @@ cdef void __getaddrinfo_handler(int code, levent.evutil_addrinfo* res, void* c_p ...@@ -323,11 +325,9 @@ cdef void __getaddrinfo_handler(int code, levent.evutil_addrinfo* res, void* c_p
cdef class getaddrinfo_request: cdef class getaddrinfo_request:
cdef public event_base base
cdef void* _ptr cdef void* _ptr
def __init__(self, event_base base, size_t ptr=0): def __init__(self, size_t ptr=0):
self.base = base
self._ptr = <void*>ptr self._ptr = <void*>ptr
property ptr: property ptr:
...@@ -339,31 +339,14 @@ cdef class getaddrinfo_request: ...@@ -339,31 +339,14 @@ cdef class getaddrinfo_request:
return '<%s ptr=%x>' % (self.__class__.__name__, self.ptr) return '<%s ptr=%x>' % (self.__class__.__name__, self.ptr)
def detach(self): def detach(self):
self.base = None
self._ptr = NULL self._ptr = NULL
def _cancel(self): def cancel(self):
cdef void* ptr = self._ptr cdef void* ptr = self._ptr
if ptr: if ptr:
self._ptr = NULL self._ptr = NULL
# self.base is already None
levent.evdns_getaddrinfo_cancel(ptr) levent.evdns_getaddrinfo_cancel(ptr)
def cancel(self):
if self._ptr and self.base is not None:
# cannot just all evdns_getaddrinfo_cancel here, because it might calls the user's callback immediateally
# and we only want to call the callbacks in the hub
self.base.active_event(self._cancel)
self.base = None
# setting base to None to let __getaddrinfo_handler figure out that the
# request was cancelled, even if _cancel was not executed yet;
# also to make sure that following up calls to cancel has not effect
@property
def pending(self):
if self._ptr:
return self.base is not None
cdef void __event_handler(int fd, short evtype, void *arg) with gil: cdef void __event_handler(int fd, short evtype, void *arg) with gil:
cdef event self = <event>arg cdef event self = <event>arg
......
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