def _iocp_recvall(self, bufsize, *args):
"""Internal use only; use 'recvall' with 'yield' instead.
"""
buf = [win32file.AllocateReadBuffer(min(bufsize, 1048576))]
pending = [bufsize]
def _recvall(err, n):
if err or n == 0:
if self._timeout and self._notifier:
self._notifier._del_timeout(self)
self._read_overlap.object = self._read_result = None
if not err:
err = winerror.ERROR_CONNECTION_INVALID
if self._read_task:
if (err == winerror.ERROR_CONNECTION_INVALID or
err == winerror.ERROR_OPERATION_ABORTED):
self._read_task._proceed_('')
else:
self._read_task.throw(socket.error(err))
else:
self._read_result.append(buf[0][:n])
pending[0] -= n
if pending[0]:
buf[0] = win32file.AllocateReadBuffer(min(pending[0], 1048576))
err, n = win32file.WSARecv(self._fileno, buf[0], self._read_overlap, 0)
if err != winerror.ERROR_IO_PENDING and err:
if self._timeout and self._notifier:
self._notifier._del_timeout(self)
self._read_overlap.object = self._read_result = None
self._read_task.throw(socket.error(err))
else:
buf[0] = ''.join(self._read_result)
if self._timeout and self._notifier:
self._notifier._del_timeout(self)
self._read_overlap.object = self._read_result = None
self._read_task._proceed_(buf[0])
if not self._scheduler:
self._scheduler = Pycos.scheduler()
self._notifier = self._scheduler._notifier
self._register()
if self._timeout:
self._notifier._add_timeout(self)
self._read_overlap.object = _recvall
self._read_result = []
self._read_task = Pycos.cur_task(self._scheduler)
self._read_task._await_()
err, n = win32file.WSARecv(self._fileno, buf[0], self._read_overlap, 0)
if err != winerror.ERROR_IO_PENDING and err:
self._read_overlap.object(err, n)
评论列表
文章目录