use strict;
use warnings;
-use Test::More tests => 29;
+use Test::More tests => 30;
use Socket qw(
AI_NUMERICHOST AF_INET SOCK_STREAM IPPROTO_TCP
'$res[0] socktype is SOCK_STREAM' );
ok( $res[0]->{protocol} == 0 || $res[0]->{protocol} == IPPROTO_TCP,
'$res[0] protocol is 0 or IPPROTO_TCP' );
-is_deeply( [ unpack_sockaddr_in $res[0]->{addr} ],
- [ 80, inet_aton( "127.0.0.1" ) ],
- '$res[0] addr is {"127.0.0.1", 80}' );
+ok( defined $res[0]->{addr},
+ '$res[0] addr is defined' );
+if (length $res[0]->{addr}) {
+ is_deeply( [ unpack_sockaddr_in $res[0]->{addr} ],
+ [ 80, inet_aton( "127.0.0.1" ) ],
+ '$res[0] addr is {"127.0.0.1", 80}' );
+} else {
+ fail( '$res[0] addr is empty: check $socksizetype' );
+}
# Check actual IV integers work just as well as PV strings
( $err, @res ) = getaddrinfo( "127.0.0.1", 80, { socktype => SOCK_STREAM } );
case "$ccisgcc" in
$define|true|[Yy])
+ # The fixed socket.h header file is wrong for gcc-4.x
+ # on PA-RISC2.0W, so Sock_type_t is size_t which is
+ # unsigned long which is 64bit which is too long
+ case "$gccversion" in
+ 4*) case "$archname" in
+ PA-RISC*) socksizetype=int ;;
+ esac
+ ;;
+ esac
+
# For the moment, don't care that it ain't supported (yet)
# by gcc (up to and including 2.95.3), cause it'll crash
# anyway. Expect auto-detection of 64-bit enabled gcc on
[ Within the sections, list each platform as a =item entry with specific
changes as paragraphs below it. ]
+=over 4
+
+=item HP-UX PA-RISC/64 now supports gcc-4.x
+
+A fix to correct the socketsize now makes the test suite pass on HP-UX
+PA-RISC for 64bitall builds.
+
+=back
+
=head2 New Platforms
XXX List any platforms that this version of perl compiles on, that previous