X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=psi.d%2Fnetdb.psi;h=7ce8427c4ba6d440d752f9628875f3c56c19f1a5;hp=259fcec6f436372c8ab3a23f8b5e1e1bb27f43d7;hb=02e801eabbe26a129ea05e6723c94e10bb653dab;hpb=7ecbe886921997a9ea3c990071c2efb97f13ac21 diff --git a/psi.d/netdb.psi b/psi.d/netdb.psi index 259fcec..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 { +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,19 +69,19 @@ function psi\getaddrinfo(string $node, string $service, array $hints, object &$r to_string(ai_canonname), to_array(*ai_next, ...) ); - free freeaddrinfo(res); + 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 = psi\NI_MAXHOST; - let host = calloc(hostlen, psi\SIZEOF_CHAR); - let servlen = psi\NI_MAXSERV; - let serv = calloc(servlen, psi\SIZEOF_CHAR); + 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 to_int(getnameinfo); + return getnameinfo(sa, salen, host, hostlen, serv, servlen, flags) as to_int(getnameinfo); set $host = to_string(host); set $service = to_string(serv); }