X-Git-Url: https://git.xinqibao.xyz/slstatus.git/blobdiff_plain/7246dc4381c6c95454672a5c1aff65a02d6d3747..cee6811036382215975792af4fa4f1624fc86a43:/components/ip.c diff --git a/components/ip.c b/components/ip.c index f98b2ed..422b448 100644 --- a/components/ip.c +++ b/components/ip.c @@ -1,5 +1,10 @@ /* See LICENSE file for copyright and license details. */ -#include +#if defined(__OpenBSD__) +#include +#include +#endif + +#include #include #include #include @@ -15,7 +20,7 @@ ipv4(const char *iface) char host[NI_MAXHOST]; if (getifaddrs(&ifaddr) == -1) { - warn("Failed to get IPv4 address for interface %s", iface); + fprintf(stderr, "getifaddrs: %s\n", strerror(errno)); return NULL; } @@ -26,7 +31,7 @@ ipv4(const char *iface) s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in), host, NI_MAXHOST, NULL, 0, NI_NUMERICHOST); if ((strcmp(ifa->ifa_name, iface) == 0) && (ifa->ifa_addr->sa_family == AF_INET)) { if (s != 0) { - warnx("Failed to get IPv4 address for interface %s", iface); + fprintf(stderr, "getnameinfo: %s\n", gai_strerror(s)); return NULL; } return bprintf("%s", host); @@ -46,7 +51,7 @@ ipv6(const char *iface) char host[NI_MAXHOST]; if (getifaddrs(&ifaddr) == -1) { - warn("Failed to get IPv6 address for interface %s", iface); + fprintf(stderr, "getifaddrs: %s\n", strerror(errno)); return NULL; } @@ -57,7 +62,7 @@ ipv6(const char *iface) s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in6), host, NI_MAXHOST, NULL, 0, NI_NUMERICHOST); if ((strcmp(ifa->ifa_name, iface) == 0) && (ifa->ifa_addr->sa_family == AF_INET6)) { if (s != 0) { - warnx("Failed to get IPv6 address for interface %s", iface); + fprintf(stderr, "getnameinfo: %s\n", gai_strerror(s)); return NULL; } return bprintf("%s", host);