chiark / gitweb /
libsystemd: make use of our common sockaddr_union everywhere
authorLennart Poettering <lennart@poettering.net>
Thu, 10 Jul 2014 19:16:40 +0000 (21:16 +0200)
committerLennart Poettering <lennart@poettering.net>
Thu, 10 Jul 2014 19:16:40 +0000 (21:16 +0200)
src/libsystemd/sd-bus/bus-internal.h
src/libsystemd/sd-daemon/sd-daemon.c

index d1183d69c430c42f744dce43c2c59e2272a65183..618e82c98f8bef1d934026009c72dd970b8c0fdc 100644 (file)
@@ -237,12 +237,7 @@ struct sd_bus {
         Hashmap *vtable_methods;
         Hashmap *vtable_properties;
 
-        union {
-                struct sockaddr sa;
-                struct sockaddr_un un;
-                struct sockaddr_in in;
-                struct sockaddr_in6 in6;
-        } sockaddr;
+        union sockaddr_union sockaddr;
         socklen_t sockaddr_size;
 
         char *kernel;
index 7caa63db1472e6edfb1c9c8a01ee49e06476cec1..46241f77ff2cba161c077eb984b0cff102f950d7 100644 (file)
@@ -37,6 +37,7 @@
 
 #include "util.h"
 #include "path-util.h"
+#include "socket-util.h"
 #include "sd-daemon.h"
 
 _public_ int sd_listen_fds(int unset_environment) {
@@ -196,14 +197,6 @@ static int sd_is_socket_internal(int fd, int type, int listening) {
         return 1;
 }
 
-union sockaddr_union {
-        struct sockaddr sa;
-        struct sockaddr_in in4;
-        struct sockaddr_in6 in6;
-        struct sockaddr_un un;
-        struct sockaddr_storage storage;
-};
-
 _public_ int sd_is_socket(int fd, int family, int type, int listening) {
         int r;
 
@@ -261,7 +254,7 @@ _public_ int sd_is_socket_inet(int fd, int family, int type, int listening, uint
                         if (l < sizeof(struct sockaddr_in))
                                 return -EINVAL;
 
-                        return htons(port) == sockaddr.in4.sin_port;
+                        return htons(port) == sockaddr.in.sin_port;
                 } else {
                         if (l < sizeof(struct sockaddr_in6))
                                 return -EINVAL;