X-Git-Url: https://git.xinqibao.xyz/slstatus.git/blobdiff_plain/e79d4932ea413c277425ff92c456741e0730c3d6..7e29da026b31f02c839b40c4dcf7bd87741a5e4a:/components/ip.c diff --git a/components/ip.c b/components/ip.c index 25071e4..85ac15e 100644 --- a/components/ip.c +++ b/components/ip.c @@ -1,10 +1,13 @@ /* See LICENSE file for copyright and license details. */ -#if defined(__linux__) -#include +#include #include #include #include #include +#if defined(__OpenBSD__) + #include + #include +#endif #include "../util.h" @@ -15,19 +18,21 @@ ipv4(const char *iface) int s; char host[NI_MAXHOST]; - if (getifaddrs(&ifaddr) == -1) { - warn("Failed to get IPv4 address for interface %s", iface); + if (getifaddrs(&ifaddr) < 0) { + fprintf(stderr, "getifaddrs: %s\n", strerror(errno)); return NULL; } for (ifa = ifaddr; ifa != NULL; ifa = ifa->ifa_next) { - if (ifa->ifa_addr == NULL) { + if (!ifa->ifa_addr) { continue; } - 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)) { + s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in), host, + NI_MAXHOST, NULL, 0, NI_NUMERICHOST); + if (!strcmp(ifa->ifa_name, iface) && + (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,19 +51,21 @@ ipv6(const char *iface) int s; char host[NI_MAXHOST]; - if (getifaddrs(&ifaddr) == -1) { - warn("Failed to get IPv6 address for interface %s", iface); + if (getifaddrs(&ifaddr) < 0) { + fprintf(stderr, "getifaddrs: %s\n", strerror(errno)); return NULL; } for (ifa = ifaddr; ifa != NULL; ifa = ifa->ifa_next) { - if (ifa->ifa_addr == NULL) { + if (!ifa->ifa_addr) { continue; } - 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)) { + s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in6), host, + NI_MAXHOST, NULL, 0, NI_NUMERICHOST); + if (!strcmp(ifa->ifa_name, iface) && + (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); @@ -69,4 +76,3 @@ ipv6(const char *iface) return NULL; } -#endif