From 393837b1cca15356b3523fbd5918fb9fcbe5514f Mon Sep 17 00:00:00 2001 From: Michael Mikonos <127171689+mknos@users.noreply.github.com> Date: Sat, 4 Jan 2025 13:15:07 +0800 Subject: [PATCH] tac: exit(1) on error * When processing multiple file arguments, and one file fails to open, exit(1) after processing all arguments to indicate something went wrong * Found when testing against GNU tac --- bin/tac | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/bin/tac b/bin/tac index 881b487c..41f1b5e2 100755 --- a/bin/tac +++ b/bin/tac @@ -25,7 +25,7 @@ use constant EX_SUCCESS => 0; use constant EX_FAILURE => 1; my $Program = basename($0); -my $VERSION = '0.18'; +my $VERSION = '0.19'; my %opts; getopts('bBrs:S:', \%opts) or usage(); @@ -57,6 +57,7 @@ unless ($fh) { exit EX_FAILURE; } print while <$fh>; +exit EX_FAILURE if $fh->get_error; exit EX_SUCCESS; sub usage { @@ -99,11 +100,12 @@ sub TIEHANDLE { *$self = { %opts, - lines => [], # Lines in memory. - scrap => '', # Incomplete line. - EOF => 0, # Finished reading current file. - count => 0, # Current line number. - ends => [], # Array of ORS for 'autoline'. + 'lines' => [], # Lines in memory. + 'scrap' => '', # Incomplete line. + 'EOF' => 0, # Finished reading current file. + 'count' => 0, # Current line number. + 'ends' => [], # Array of ORS for 'autoline'. + 'error' => 0, }; # Set mode for opening file. @@ -120,15 +122,18 @@ sub TIEHANDLE { *$self->{'files'} = []; foreach my $file (@files) { if (-d $file) { + *$self->{'error'} = 1; warn "$Program: '$file' is a directory\n"; next; } my $fh; unless (sysopen $fh, $file, $mode) { + *$self->{'error'} = 1; warn "$Program: failed to open '$file': $!\n"; next; } unless (sysseek $fh, 0, 2) { + *$self->{'error'} = 1; warn "$Program: seek failed for '$file': $!\n"; next; } @@ -194,6 +199,11 @@ sub READLINE { pop @{*$self->{lines}}; } +sub get_error { + my $self = shift; + return *$self->{'error'}; +} + sub get_lines { my $self = shift;