Sys::Hostname should localize $SIG{__DIE__}
Ken Shan [Sun, 6 Jul 1997 11:48:39 +0000 (23:48 +1200)]
~s Sys::Hostname should localize $SIG{__DIE__}

When Sys::Hostname is trying various methods to get the hostname,
it should localize $SIG{__DIE__}.  Patch follows.  (I'm not sure
if $SIG{__WARN__} should also be localized.)

p5p-msgid: 199707070357.XAA18065@digitas.harvard.edu

lib/Sys/Hostname.pm

index 92207ac..360d0eb 100644 (file)
@@ -39,7 +39,8 @@ sub hostname {
   if ($^O eq 'VMS') {
 
     # method 2 - no sockets ==> return DECnet node name
-    eval {my($test) = gethostbyname('me')}; # returns 'me' on most systems
+    eval {local $SIG{'__DIE__'};
+          my($test) = gethostbyname('me')}; # returns 'me' on most systems
     if ($@) { return $host = $ENV{'SYS$NODE'}; }
 
     # method 3 - has someone else done the job already?  It's common for the
@@ -69,6 +70,7 @@ sub hostname {
 
     # method 2 - syscall is preferred since it avoids tainting problems
     eval {
+        local $SIG{'__DIE__'};
        {
            package main;
            require "syscall.ph";
@@ -79,16 +81,19 @@ sub hostname {
 
     # method 3 - trusty old hostname command
     || eval {
+        local $SIG{'__DIE__'};
        $host = `(hostname) 2>/dev/null`; # bsdish
     }
 
     # method 4 - sysV uname command (may truncate)
     || eval {
+        local $SIG{'__DIE__'};
        $host = `uname -n 2>/dev/null`; ## sysVish
     }
 
     # method 5 - Apollo pre-SR10
     || eval {
+        local $SIG{'__DIE__'};
        ($host,$a,$b,$c,$d)=split(/[:\. ]/,`/com/host`,6);
     }