ensure implicit close on local(*FH) doesn't affect $! and thence $?
Gurusamy Sarathy [Sun, 2 Aug 1998 04:21:48 +0000 (04:21 +0000)]
p4raw-id: //depot/maint-5.005/perl@1687

sv.c
t/op/die_exit.t

diff --git a/sv.c b/sv.c
index 3652b9d..72007b1 100644 (file)
--- a/sv.c
+++ b/sv.c
@@ -2885,7 +2885,8 @@ sv_clear(register SV *sv)
     stash = NULL;
     switch (SvTYPE(sv)) {
     case SVt_PVIO:
-       if (IoIFP(sv) != PerlIO_stdin() &&
+       if (IoIFP(sv) &&
+           IoIFP(sv) != PerlIO_stdin() &&
            IoIFP(sv) != PerlIO_stdout() &&
            IoIFP(sv) != PerlIO_stderr())
          io_close((IO*)sv);
index b5760d6..ffbb1e0 100755 (executable)
@@ -30,6 +30,8 @@ my %tests = (
        14 => [ 255,   0],
        15 => [ 255,   1],
        16 => [ 255, 256],
+       # see if implicit close preserves $?
+       17 => [  42,  42, '{ local *F; open F, q[TEST]; close F } die;'],
 );
 
 my $max = keys %tests;
@@ -37,11 +39,12 @@ my $max = keys %tests;
 print "1..$max\n";
 
 foreach my $test (1 .. $max) {
-    my($bang, $query) = @{$tests{$test}};
+    my($bang, $query, $code) = @{$tests{$test}};
+    $code ||= 'die;';
     my $exit =
        ($^O eq 'MSWin32'
-        ? system qq($perl -e "\$! = $bang; \$? = $query; die;" 2> nul)
-        : system qq($perl -e '\$! = $bang; \$? = $query; die;' 2> /dev/null));
+        ? system qq($perl -e "\$! = $bang; \$? = $query; $code" 2> nul)
+        : system qq($perl -e '\$! = $bang; \$? = $query; $code' 2> /dev/null));
 
     printf "# 0x%04x  0x%04x  0x%04x\nnot ", $exit, $bang, $query
        unless $exit == (($bang || ($query >> 8) || 255) << 8);