summaryrefslogtreecommitdiff
path: root/usr.sbin/pkg_add
diff options
context:
space:
mode:
authorMarc Espie <espie@cvs.openbsd.org>2009-11-15 08:59:33 +0000
committerMarc Espie <espie@cvs.openbsd.org>2009-11-15 08:59:33 +0000
commita826ac6e18e54109f0feca6836253e8f2f54222a (patch)
tree3c489b95793562cfab07c2c39e9a0e4d67c29371 /usr.sbin/pkg_add
parent56389f1cef91b3903eeb93d6389f0de85b30f3aa (diff)
common code, handle SIG{CONT} in both cases.
Diffstat (limited to 'usr.sbin/pkg_add')
-rw-r--r--usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm33
1 files changed, 17 insertions, 16 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm b/usr.sbin/pkg_add/OpenBSD/ProgressMeter.pm
index 412c7da646a..122775793d8 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.16 2009/11/11 12:32:03 espie Exp $
+# $OpenBSD: ProgressMeter.pm,v 1.17 2009/11/15 08:59:32 espie Exp $
#
# Copyright (c) 2004-2007 Marc Espie <espie@openbsd.org>
#
@@ -88,24 +88,29 @@ sub set_header
return $isatty;
}
+sub _show
+{
+ my ($self, $d) = @_;
+
+ return if $d eq $lastdisplay && !$continued;
+ $lastdisplay=$d;
+ $continued = 0;
+ print $d, "\r";
+}
+
sub message
{
my $self = shift;
return unless $isatty;
my $message = shift;
- my $d;
if ($playfield > length($message)) {
$message .= ' 'x($playfield - length($message));
}
if ($playfield) {
- $d = "$header|".substr($message, 0, $playfield);
+ $self->_show("$header|".substr($message, 0, $playfield));
} else {
- $d = $header;
+ $self->_show($header);
}
- return if $d eq $lastdisplay && !$continued;
- $lastdisplay=$d;
- $continued = 0;
- print $d, "\r";
}
sub show
@@ -113,18 +118,14 @@ sub show
my $self = shift;
return unless $isatty;
my ($current, $total) = @_;
- my $d;
if ($playfield) {
- my $stars = int (($current * $playfield) / $total + 0.5);
- my $percent = int (($current * 100)/$total + 0.5);
- $d = "$header|".'*'x$stars.' 'x($playfield-$stars)."| ".$percent."\%";
+ my $stars = int (($current * $playfield) / $total + 0.5);
+ my $percent = int (($current * 100)/$total + 0.5);
+ $self->_show("$header|".'*'x$stars.' 'x($playfield-$stars)."| ".$percent."\%");
} else {
- $d = $header;
+ $self->_show( $header);
}
- return if $d eq $lastdisplay;
- $lastdisplay=$d;
- print $d, "\r";
}
sub clear