aboutsummaryrefslogtreecommitdiffstats
path: root/Rpmdrake/gurpm.pm
diff options
context:
space:
mode:
authorThierry Vignaud <tv@mageia.org>2012-02-15 19:31:36 +0000
committerThierry Vignaud <tv@mageia.org>2012-02-15 19:31:36 +0000
commit6b7588c497ad9a6c551efad97f7a8ea58fd445bf (patch)
tree74f96b68b23d831816c8fac18f09423c21d4327c /Rpmdrake/gurpm.pm
parente948a8c125fcdedd7f126d24ee499a6edd316574 (diff)
downloadrpmdrake-6b7588c497ad9a6c551efad97f7a8ea58fd445bf.tar
rpmdrake-6b7588c497ad9a6c551efad97f7a8ea58fd445bf.tar.gz
rpmdrake-6b7588c497ad9a6c551efad97f7a8ea58fd445bf.tar.bz2
rpmdrake-6b7588c497ad9a6c551efad97f7a8ea58fd445bf.tar.xz
rpmdrake-6b7588c497ad9a6c551efad97f7a8ea58fd445bf.zip
(progress) limit progress bar refreshes to 3 per second max (mga#2775)
Diffstat (limited to 'Rpmdrake/gurpm.pm')
-rw-r--r--Rpmdrake/gurpm.pm5
1 files changed, 5 insertions, 0 deletions
diff --git a/Rpmdrake/gurpm.pm b/Rpmdrake/gurpm.pm
index 3a9017c9..ea77d419 100644
--- a/Rpmdrake/gurpm.pm
+++ b/Rpmdrake/gurpm.pm
@@ -28,6 +28,8 @@ use lib qw(/usr/lib/libDrakX);
use mygtk2 qw(gtknew); #- do not import anything else, especially gtkadd() which conflicts with ugtk2 one
use ugtk2 qw(:all);
use base qw(ugtk2);
+use Time::HiRes;
+use feature 'state';
sub new {
@@ -61,9 +63,12 @@ sub label {
sub progress {
my ($self, $fraction) = @_;
+ state $time;
$fraction = 0 if $fraction < 0;
$fraction = 1 if 1 < $fraction;
$self->{progressbar}->set_fraction($fraction);
+ return if Time::HiRes::clock_gettime() - $time < 0.333;
+ $time = Time::HiRes::clock_gettime();
$self->flush;
}