[pve-devel] [PATCH 2/2] new helper: getaddrinfo_all
Wolfgang Bumiller
w.bumiller at proxmox.com
Mon May 11 16:24:25 CEST 2015
As it's commonly used in ipv6 support code a getaddrinfo wrapper passing
default flags and dealing with the (err,result) tuple was added.
---
src/PVE/Tools.pm | 15 ++++++++++-----
1 file changed, 10 insertions(+), 5 deletions(-)
diff --git a/src/PVE/Tools.pm b/src/PVE/Tools.pm
index cc181ee..1ff085f 100644
--- a/src/PVE/Tools.pm
+++ b/src/PVE/Tools.pm
@@ -1052,14 +1052,19 @@ sub unpack_sockaddr_in46 {
return ($family, $port, $host);
}
-sub get_host_address_family {
- my ($hostname, $socktype) = @_;
+sub getaddrinfo_all {
+ my ($hostname, @opts) = @_;
my %hints = ( flags => AI_V4MAPPED | AI_ALL,
- socktype => $socktype );
+ @opts );
my ($err, @res) = Socket::getaddrinfo($hostname, '0', \%hints);
- die "failed to resolve $hostname: $err\n" if $err;
+ die "failed to get address info for: $hostname: $err\n" if $err;
+ return @res;
+}
- return ${res[0]}->{family};
+sub get_host_address_family {
+ my ($hostname, $socktype) = @_;
+ my @res = getaddrinfo_all($hostname, socktype => $socktype);
+ return $res[0]->{family};
}
1;
--
2.1.4
More information about the pve-devel
mailing list