X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fnetwork%2Finet_ntop.c;h=14f9f4c4018ed5dc0a3a4c9db1839c411135bfad;hb=7cbb6f70c8fe711644ec0dbede1973cc6641a283;hp=3e8a6db0d96b6876d311e301f2b5024b09c836fb;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01;p=musl diff --git a/src/network/inet_ntop.c b/src/network/inet_ntop.c index 3e8a6db0..14f9f4c4 100644 --- a/src/network/inet_ntop.c +++ b/src/network/inet_ntop.c @@ -1,12 +1,10 @@ #include -#include #include -#include #include #include #include -const char *inet_ntop(int af, const void *a0, char *s, socklen_t l) +const char *inet_ntop(int af, const void *restrict a0, char *restrict s, socklen_t l) { const unsigned char *a = a0; int i, j, max, best; @@ -18,12 +16,20 @@ const char *inet_ntop(int af, const void *a0, char *s, socklen_t l) return s; break; case AF_INET6: - memset(buf, 'x', sizeof buf); - buf[sizeof buf-1]=0; - snprintf(buf, sizeof buf, - "%.0x%x:%.0x%x:%.0x%x:%.0x%x:%.0x%x:%.0x%x:%.0x%x:%.0x%x", - a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7], - a[8],a[9],a[10],a[11],a[12],a[13],a[14],a[15]); + if (memcmp(a, "\0\0\0\0\0\0\0\0\0\0\377\377", 12)) + snprintf(buf, sizeof buf, + "%x:%x:%x:%x:%x:%x:%x:%x", + 256*a[0]+a[1],256*a[2]+a[3], + 256*a[4]+a[5],256*a[6]+a[7], + 256*a[8]+a[9],256*a[10]+a[11], + 256*a[12]+a[13],256*a[14]+a[15]); + else + snprintf(buf, sizeof buf, + "%x:%x:%x:%x:%x:%x:%d.%d.%d.%d", + 256*a[0]+a[1],256*a[2]+a[3], + 256*a[4]+a[5],256*a[6]+a[7], + 256*a[8]+a[9],256*a[10]+a[11], + a[12],a[13],a[14],a[15]); /* Replace longest /(^0|:)[:0]{2,}/ with "::" */ for (i=best=0, max=2; buf[i]; i++) { if (i && buf[i] != ':') continue; @@ -32,7 +38,7 @@ const char *inet_ntop(int af, const void *a0, char *s, socklen_t l) } if (max>2) { buf[best] = buf[best+1] = ':'; - strcpy(buf+best+2, buf+best+max); + memmove(buf+best+2, buf+best+max, i-best-max+1); } if (strlen(buf) < l) { strcpy(s, buf);