diff options
author | Yu Watanabe <watanabe.yu+github@gmail.com> | 2020-07-13 07:09:55 +0900 |
---|---|---|
committer | Yu Watanabe <watanabe.yu+github@gmail.com> | 2020-07-21 03:55:34 +0900 |
commit | 408f8fbc0fc3b7b50f7aab6cc57af9bdf2202014 (patch) | |
tree | 875246099dee1387a46b21aae042cda31beec440 /src/shared/socket-netlink.c | |
parent | a723fb85dac86fb975e52aeed68dcd62d3f2b3b4 (diff) | |
download | systemd-408f8fbc0fc3b7b50f7aab6cc57af9bdf2202014.tar.gz |
util: introduce 'struct in_addr_full' and its helper functions
Diffstat (limited to 'src/shared/socket-netlink.c')
-rw-r--r-- | src/shared/socket-netlink.c | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/src/shared/socket-netlink.c b/src/shared/socket-netlink.c index b95407f10e..d72a70503a 100644 --- a/src/shared/socket-netlink.c +++ b/src/shared/socket-netlink.c @@ -454,3 +454,70 @@ int in_addr_port_ifindex_name_from_string_auto( return r; } + +struct in_addr_full *in_addr_full_free(struct in_addr_full *a) { + if (!a) + return NULL; + + free(a->server_name); + free(a->cached_server_string); + return mfree(a); +} + +int in_addr_full_new(int family, union in_addr_union *a, uint16_t port, int ifindex, const char *server_name, struct in_addr_full **ret) { + _cleanup_free_ char *name = NULL; + struct in_addr_full *x; + + assert(ret); + + if (!isempty(server_name)) { + name = strdup(server_name); + if (!name) + return -ENOMEM; + } + + x = new(struct in_addr_full, 1); + if (!x) + return -ENOMEM; + + *x = (struct in_addr_full) { + .family = family, + .address = *a, + .port = port, + .ifindex = ifindex, + .server_name = TAKE_PTR(name), + }; + + *ret = x; + return 0; +} + +int in_addr_full_new_from_string(const char *s, struct in_addr_full **ret) { + _cleanup_free_ char *server_name = NULL; + int family, ifindex, r; + union in_addr_union a; + uint16_t port; + + assert(s); + + r = in_addr_port_ifindex_name_from_string_auto(s, &family, &a, &port, &ifindex, &server_name); + if (r < 0) + return r; + + return in_addr_full_new(family, &a, port, ifindex, server_name, ret); +} + +const char *in_addr_full_to_string(struct in_addr_full *a) { + assert(a); + + if (!a->cached_server_string) + (void) in_addr_port_ifindex_name_to_string( + a->family, + &a->address, + a->port, + a->ifindex, + a->server_name, + &a->cached_server_string); + + return a->cached_server_string; +} |