From efac9b37241d0603817b00a8a15108aa6a8ccc42 Mon Sep 17 00:00:00 2001 From: Marc Espie Date: Mon, 18 Oct 2004 13:29:15 +0000 Subject: take window size into account. window sizes changes are delayed, nothing to do about it, since perl keeps the signal around until it is safe to activate it... --- usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm | 57 +++++++++++++++++++++++++------ 1 file changed, 47 insertions(+), 10 deletions(-) diff --git a/usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm b/usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm index 24461fe2cee..723957639d0 100644 --- a/usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm +++ b/usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: ProgressMeter.pm,v 1.1 2004/10/18 12:03:19 espie Exp $ +# $OpenBSD: ProgressMeter.pm,v 1.2 2004/10/18 13:29:14 espie Exp $ # # Copyright (c) 2004 Marc Espie # @@ -26,9 +26,38 @@ my $isatty; my $enabled = 0; # unless we know better -my $width = 80; +my $width; my $playfield; +my $wsz_format = 'SSSS'; +our %sizeof; + +sub find_window_size +{ + return if defined $width; + # try to get exact window width + my $r; + $r = pack($wsz_format, 0, 0, 0, 0); + $sizeof{'struct winsize'} = 8; + require 'sys/ttycom.ph'; + $width = 80; + if (ioctl(STDERR, &TIOCGWINSZ, $r) == 0) { + my ($rows, $cols, $xpix, $ypix) = + unpack($wsz_format, $r); + $width = $cols; + } +} + +sub compute_playfield +{ + return unless $isatty; + # compute playfield + $playfield = $width - length($header) - 10; + if ($playfield < 5) { + $playfield = 0; + } +} + sub enable { $enabled = 1; @@ -43,13 +72,16 @@ sub set_header if (!defined $isatty) { $isatty = -t STDERR; } + find_window_size(); } if ($isatty) { - # compute playfield - $playfield = $width - length($header) - 10; - if ($playfield > 40) { - $playfield = 40; - } + find_window_size(); + compute_playfield(); + $SIG{'WINCH'} = sub { + $width = undef; + find_window_size(); + compute_playfield(); + }; } return $isatty; } @@ -58,10 +90,15 @@ sub show { my ($current, $total) = @_; return unless $isatty; + my $d; - my $stars = ($current * $playfield) / $total; - my $percent = int (($current * 100)/$total + 0.5); - my $d = "$header|".'*'x$stars.' 'x($playfield-$stars)."| ".$percent."\%"; + if ($playfield) { + my $stars = ($current * $playfield) / $total; + my $percent = int (($current * 100)/$total + 0.5); + $d = "$header|".'*'x$stars.' 'x($playfield-$stars)."| ".$percent."\%"; + } else { + $d = $header; + } return if $d eq $lastdisplay; $lastdisplay=$d; print STDERR $d, "\r"; -- cgit v1.2.3