mirror of
https://github.com/status-im/nim-chronos.git
synced 2025-02-20 23:18:22 +00:00
Properly fix cancellation race and not introduce FD leaks. (#102)
This commit is contained in:
parent
d6d0084333
commit
bedd1ded5e
@ -629,8 +629,9 @@ elif unixPlatform:
|
||||
let loop = getGlobalDispatcher()
|
||||
|
||||
proc continuation(udata: pointer) =
|
||||
unregister(fd)
|
||||
close(SocketHandle(fd))
|
||||
if SocketHandle(fd) in loop.selector:
|
||||
unregister(fd)
|
||||
close(SocketHandle(fd))
|
||||
if not isNil(aftercb):
|
||||
aftercb(nil)
|
||||
|
||||
|
@ -722,8 +722,7 @@ when defined(windows):
|
||||
GC_unref(ovl)
|
||||
|
||||
proc cancel(udata: pointer) {.gcsafe.} =
|
||||
if not(retFuture.finished()):
|
||||
sock.closeSocket()
|
||||
sock.closeSocket()
|
||||
|
||||
povl = RefCustomOverlapped()
|
||||
GC_ref(povl)
|
||||
@ -1251,8 +1250,7 @@ else:
|
||||
retFuture.complete(transp)
|
||||
|
||||
proc cancel(udata: pointer) {.gcsafe.} =
|
||||
if not(retFuture.finished()):
|
||||
closeSocket(sock)
|
||||
closeSocket(sock)
|
||||
|
||||
while true:
|
||||
var res = posix.connect(SocketHandle(sock),
|
||||
|
Loading…
x
Reference in New Issue
Block a user