fixing unfreed memory leak with `freeAddrInfo()` (#425)

* fixing unfreed memory leak with `freeAddrInfo()`

* `freeaddrinfo` to `freeAddrInfo()`
This commit is contained in:
rockcavera 2023-07-31 19:28:34 -03:00 committed by GitHub
parent d214bcfb4f
commit 5c39bf47be
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 7 deletions

View File

@ -708,7 +708,7 @@ when defined(windows):
res: var ptr AddrInfo): cint {. res: var ptr AddrInfo): cint {.
stdcall, dynlib: "ws2_32", importc: "getaddrinfo", sideEffect.} stdcall, dynlib: "ws2_32", importc: "getaddrinfo", sideEffect.}
proc freeaddrinfo*(ai: ptr AddrInfo) {. proc freeAddrInfo*(ai: ptr AddrInfo) {.
stdcall, dynlib: "ws2_32", importc: "freeaddrinfo", sideEffect.} stdcall, dynlib: "ws2_32", importc: "freeaddrinfo", sideEffect.}
proc createIoCompletionPort*(fileHandle: HANDLE, proc createIoCompletionPort*(fileHandle: HANDLE,
@ -880,7 +880,7 @@ elif defined(macos) or defined(macosx):
sigemptyset, sigaddset, sigismember, fcntl, accept, sigemptyset, sigaddset, sigismember, fcntl, accept,
pipe, write, signal, read, setsockopt, getsockopt, pipe, write, signal, read, setsockopt, getsockopt,
getcwd, chdir, waitpid, kill, select, pselect, getcwd, chdir, waitpid, kill, select, pselect,
socketpair, socketpair, freeAddrInfo,
Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr, Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr,
SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6, SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6,
Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet, Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet,
@ -905,7 +905,7 @@ elif defined(macos) or defined(macosx):
sigemptyset, sigaddset, sigismember, fcntl, accept, sigemptyset, sigaddset, sigismember, fcntl, accept,
pipe, write, signal, read, setsockopt, getsockopt, pipe, write, signal, read, setsockopt, getsockopt,
getcwd, chdir, waitpid, kill, select, pselect, getcwd, chdir, waitpid, kill, select, pselect,
socketpair, socketpair, freeAddrInfo,
Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr, Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr,
SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6, SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6,
Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet, Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet,
@ -947,7 +947,7 @@ elif defined(linux):
unlink, listen, sendmsg, recvmsg, getpid, fcntl, unlink, listen, sendmsg, recvmsg, getpid, fcntl,
pthread_sigmask, sigprocmask, clock_gettime, signal, pthread_sigmask, sigprocmask, clock_gettime, signal,
getcwd, chdir, waitpid, kill, select, pselect, getcwd, chdir, waitpid, kill, select, pselect,
socketpair, socketpair, freeAddrInfo,
ClockId, Itimerspec, Timespec, Sigset, Time, Pid, Mode, ClockId, Itimerspec, Timespec, Sigset, Time, Pid, Mode,
SigInfo, Id, Tmsghdr, IOVec, RLimit, Timeval, TFdSet, SigInfo, Id, Tmsghdr, IOVec, RLimit, Timeval, TFdSet,
SockAddr, SockLen, Sockaddr_storage, Sockaddr_in, SockAddr, SockLen, Sockaddr_storage, Sockaddr_in,
@ -974,7 +974,7 @@ elif defined(linux):
unlink, listen, sendmsg, recvmsg, getpid, fcntl, unlink, listen, sendmsg, recvmsg, getpid, fcntl,
pthread_sigmask, sigprocmask, clock_gettime, signal, pthread_sigmask, sigprocmask, clock_gettime, signal,
getcwd, chdir, waitpid, kill, select, pselect, getcwd, chdir, waitpid, kill, select, pselect,
socketpair, socketpair, freeAddrInfo,
ClockId, Itimerspec, Timespec, Sigset, Time, Pid, Mode, ClockId, Itimerspec, Timespec, Sigset, Time, Pid, Mode,
SigInfo, Id, Tmsghdr, IOVec, RLimit, TFdSet, Timeval, SigInfo, Id, Tmsghdr, IOVec, RLimit, TFdSet, Timeval,
SockAddr, SockLen, Sockaddr_storage, Sockaddr_in, SockAddr, SockLen, Sockaddr_storage, Sockaddr_in,
@ -1097,7 +1097,7 @@ elif defined(freebsd) or defined(openbsd) or defined(netbsd) or
sigaddset, sigismember, fcntl, accept, pipe, write, sigaddset, sigismember, fcntl, accept, pipe, write,
signal, read, setsockopt, getsockopt, clock_gettime, signal, read, setsockopt, getsockopt, clock_gettime,
getcwd, chdir, waitpid, kill, select, pselect, getcwd, chdir, waitpid, kill, select, pselect,
socketpair, socketpair, freeAddrInfo,
Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr, Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr,
SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6, SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6,
Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet, Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet,
@ -1123,7 +1123,7 @@ elif defined(freebsd) or defined(openbsd) or defined(netbsd) or
sigaddset, sigismember, fcntl, accept, pipe, write, sigaddset, sigismember, fcntl, accept, pipe, write,
signal, read, setsockopt, getsockopt, clock_gettime, signal, read, setsockopt, getsockopt, clock_gettime,
getcwd, chdir, waitpid, kill, select, pselect, getcwd, chdir, waitpid, kill, select, pselect,
socketpair, socketpair, freeAddrInfo,
Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr, Timeval, Timespec, Pid, Mode, Time, Sigset, SockAddr,
SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6, SockLen, Sockaddr_storage, Sockaddr_in, Sockaddr_in6,
Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet, Sockaddr_un, SocketHandle, AddrInfo, RLimit, TFdSet,

View File

@ -298,6 +298,9 @@ proc getAddrInfo(address: string, port: Port, domain: Domain,
raises: [TransportAddressError].} = raises: [TransportAddressError].} =
## We have this one copy of ``getAddrInfo()`` because of AI_V4MAPPED in ## We have this one copy of ``getAddrInfo()`` because of AI_V4MAPPED in
## ``net.nim:getAddrInfo()``, which is not cross-platform. ## ``net.nim:getAddrInfo()``, which is not cross-platform.
##
## Warning: `ptr AddrInfo` returned by `getAddrInfo()` needs to be freed by
## calling `freeAddrInfo()`.
var hints: AddrInfo var hints: AddrInfo
var res: ptr AddrInfo = nil var res: ptr AddrInfo = nil
hints.ai_family = toInt(domain) hints.ai_family = toInt(domain)
@ -420,6 +423,7 @@ proc resolveTAddress*(address: string, port: Port,
if ta notin res: if ta notin res:
res.add(ta) res.add(ta)
it = it.ai_next it = it.ai_next
freeAddrInfo(aiList)
res res
proc resolveTAddress*(address: string, domain: Domain): seq[TransportAddress] {. proc resolveTAddress*(address: string, domain: Domain): seq[TransportAddress] {.