X-Git-Url: http://git.shiar.nl/barcat.git/blobdiff_plain/8407b1f712b9885d741a1f5d01b8ca2d0fb37905..160ad46ac34e34834b8fb128092f6e4942dd072e:/barcat diff --git a/barcat b/barcat index 1b780e6..1b7cd21 100755 --- a/barcat +++ b/barcat @@ -43,10 +43,14 @@ GetOptions(\%opt, ); }, 'markers|m=s', + 'graph-format=s' => sub { + $opt{'graph-format'} = substr $_[1], 0, 1; + }, 'spark:s' => sub { - $opt{spark} = [split //, $_[1] || '⎽▁▂▃▄▅▆▇█']; + $opt{spark} = [split //, $_[1] || '▁▂▃▄▅▆▇█']; }, 'stat|s!', + 'signal-stat=s', 'unmodified|u!', 'width|w=i', 'usage|h' => sub { @@ -75,18 +79,22 @@ GetOptions(\%opt, $opt{width} ||= $ENV{COLUMNS} || 80; $opt{color} //= -t *STDOUT; # enable on tty +$opt{'graph-format'} //= '-'; $opt{trim} *= $opt{width} / 100 if $opt{trimpct}; $opt{units} = [split //, ' kMGTPEZYyzafpnμm'] if $opt{'human-readable'}; $opt{anchor} //= qr/\A/; $opt{'value-length'} = 6 if $opt{units}; $opt{'value-length'} = 1 if $opt{unmodified}; +$opt{'signal-stat'} //= exists $SIG{INFO} ? 'INFO' : 'QUIT'; my (@lines, @values, @order); +$SIG{$_} = \&show_stat for $opt{'signal-stat'} || (); $SIG{ALRM} = sub { show_lines(); alarm $opt{interval} if defined $opt{interval} and $opt{interval} > 0; }; +$SIG{INT} = \&show_exit; if (defined $opt{interval}) { $opt{interval} ||= 1; @@ -98,11 +106,6 @@ if (defined $opt{interval}) { } or warn $@, "Expect slowdown with large datasets!\n"; } -$SIG{INT} = sub { - $SIG{INT} = 'DEFAULT'; # reset for subsequent attempts - 'IGNORE' # continue after assumed eof -}; - my $valmatch = qr/$opt{anchor} ( \h* -? [0-9]* \.? [0-9]+ (?: e[+-]?[0-9]+ )? |)/x; while (readline) { s/\r?\n\z//; @@ -204,7 +207,7 @@ while ($nr <= $#lines) { } my $line = $lines[$nr] =~ s/\n/$val/r; printf '%-*s', $len + length($val), $line; - print $barmark[$_] // '-' for 1 .. $size && (($values[$nr] || 0) - $minval) * $size + .5; + print $barmark[$_] // $opt{'graph-format'} for 1 .. $size && (($values[$nr] || 0) - $minval) * $size + .5; say ''; } continue { @@ -213,9 +216,8 @@ continue { say '' if $opt{spark}; } -show_lines(); -if ($opt{stat}) { +sub show_stat { if ($opt{hidemin} or $opt{hidemax}) { $opt{hidemin} ||= 1; $opt{hidemax} ||= @lines; @@ -234,6 +236,15 @@ if ($opt{stat}) { say ''; } +sub show_exit { + show_lines(); + show_stat() if $opt{stat}; + exit 130 if @_; # 0x80+signo + exit; +} + +show_exit(); + __END__ =encoding utf8 @@ -307,6 +318,11 @@ Stop output after a number of lines. All input is still counted and analyzed for statistics, but disregarded for padding and bar size. +=item --graph-format= + +Glyph to repeat for the graph line. +Defaults to a dash C<->. + =item -m, --markers= Statistical positions to indicate on bars.