X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=psi.d%2Fnetdb.psi;h=7ce8427c4ba6d440d752f9628875f3c56c19f1a5;hp=dd81ed882de993602f2e670fd1c91b4f75ca3272;hb=02e801eabbe26a129ea05e6723c94e10bb653dab;hpb=cfebc76ed7426836f21296cca9a14b422bfa04cf diff --git a/psi.d/netdb.psi b/psi.d/netdb.psi index dd81ed8..7ce8427 100644 --- a/psi.d/netdb.psi +++ b/psi.d/netdb.psi @@ -1,35 +1,39 @@ +lib "anl"; + +#include + function psi\endhostent() : void { - return void(endhostent); + return endhostent() as void(endhostent); } -function psi\endnetend() : void { - return void(endnetent); +function psi\endnetent() : void { + return endnetent() as void(endnetent); } function psi\endprotoent() : void { - return void(endprotoent); + return endprotoent() as void(endprotoent); } function psi\endservent() : void { - return void(endservent); + return endservent() as void(endservent); } function psi\sethostent(bool $stayopen) : void { let stayopen = intval($stayopen); - return void(sethostent); + return sethostent(stayopen) as void(sethostent); } -function psi\setnetset(bool $stayopen) : void { +function psi\setnetent(bool $stayopen) : void { let stayopen = intval($stayopen); - return void(setnetent); + return setnetent(stayopen) as void(setnetent); } function psi\setprotoent(bool $stayopen) : void { let stayopen = intval($stayopen); - return void(setprotoent); + return setprotoent(stayopen) as void(setprotoent); } function psi\setservent(bool $stayopen) : void { let stayopen = intval($stayopen); - return void(setservent); + return setservent(stayopen) as void(setservent); } function psi\gethostent() : array { - return to_array(gethostent, + return gethostent() as to_array(*gethostent, to_string(h_name), to_array(h_aliases, to_string(h_aliases)), to_int(h_addrtype), @@ -40,16 +44,21 @@ function psi\gethostent() : array { function psi\gai_strerror(int $errcode) : string { let errcode = intval($errcode); - return to_string(gai_strerror); + return gai_strerror(errcode) as to_string(gai_strerror); } -// extern int getaddrinfo(const char *node, const char *service, const struct addrinfo *hints, struct addrinfo **res); -function psi\getaddrinfo(string $node, string $service, array $hints, object &$res = NULL) : int { +// extern int getaddrinfo(const char *node, const char *service, const struct addrinfo *hints, struct addrinfo **res) +function psi\getaddrinfo(string $node, string $service, array $hints = NULL, object &$res = NULL) : int { let node = strval($node); let service = strval($service); - let hints = arrval($hints); + let hints = &arrval($hints, + intval($ai_flags), + intval($ai_family), + intval($ai_socktype), + intval($ai_protocol) + ); let res = &NULL; - return to_int(getaddrinfo); + return getaddrinfo(node, service, hints, res) as to_int(getaddrinfo); set $res = to_array(**res, to_int(ai_flags), to_int(ai_family), @@ -60,5 +69,19 @@ function psi\getaddrinfo(string $node, string $service, array $hints, object &$r to_string(ai_canonname), to_array(*ai_next, ...) ); - free freeaddrinfo(res); -} \ No newline at end of file + free freeaddrinfo(*res); +} + +// extern int getnameinfo(struct sockaddr *sa, socklen_t salen, char *host, socklen_t hostlen, char *serv, socklen_t servlen, int flags) +function psi\getnameinfo(string $addr, string &$host = NULL, string &$service = NULL, int $flags = 0) : int { + let sa = strval($addr); + let salen = strlen($addr); + let hostlen = NI_MAXHOST; + let host = calloc(hostlen, sizeof(char)); + let servlen = NI_MAXSERV; + let serv = calloc(servlen, sizeof(char)); + let flags = intval($flags); + return getnameinfo(sa, salen, host, hostlen, serv, servlen, flags) as to_int(getnameinfo); + set $host = to_string(host); + set $service = to_string(serv); +}