X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=src%2Ffake-getaddrinfo.c;fp=src%2Ffake-getaddrinfo.c;h=9aaddaf8c2fe2f6270558765b1ee17abaa34cda6;hb=b67296418c51784d39a24c3041e2cb199bee06f2;hp=37a65b894b46c687277753f95b24d4366dc0c184;hpb=f79cc0e0bba16a3aa42a5fa13098cda714623205;p=meshlink diff --git a/src/fake-getaddrinfo.c b/src/fake-getaddrinfo.c index 37a65b89..9aaddaf8 100644 --- a/src/fake-getaddrinfo.c +++ b/src/fake-getaddrinfo.c @@ -20,10 +20,13 @@ char *gai_strerror(int ecode) { switch(ecode) { case EAI_NODATA: return "No address associated with hostname"; + case EAI_MEMORY: return "Memory allocation failure"; + case EAI_FAMILY: return "Address family not supported"; + default: return "Unknown error"; } @@ -65,11 +68,13 @@ int getaddrinfo(const char *hostname, const char *servname, const struct addrinf int i; uint16_t port = 0; - if(hints && hints->ai_family != AF_INET && hints->ai_family != AF_UNSPEC) + if(hints && hints->ai_family != AF_INET && hints->ai_family != AF_UNSPEC) { return EAI_FAMILY; + } - if(servname) + if(servname) { port = htons(atoi(servname)); + } if(hints && hints->ai_flags & AI_PASSIVE) { *res = malloc_ai(port, htonl(0x00000000)); @@ -83,14 +88,16 @@ int getaddrinfo(const char *hostname, const char *servname, const struct addrinf hp = gethostbyname(hostname); - if(!hp || !hp->h_addr_list || !hp->h_addr_list[0]) + if(!hp || !hp->h_addr_list || !hp->h_addr_list[0]) { return EAI_NODATA; + } for(i = 0; hp->h_addr_list[i]; i++) { *res = malloc_ai(port, ((struct in_addr *)hp->h_addr_list[i])->s_addr); - if(prev) + if(prev) { prev->ai_next = *res; + } prev = *res; }