Acme-ProgressBar
view release on metacpan or search on metacpan
lib/Acme/ProgressBar.pm view on Meta::CPAN
#pod code.
#pod
#pod =cut
sub progress(&) { ## no critic Prototype
my ($code) = @_;
local $| = 1; ## no critic
_overprint(_message(0,10,undef));
my $begun = Time::HiRes::time;
$code->();
my $total = Time::HiRes::time - $begun;
for (1 .. 9) {
_overprint(_message($_,10,$total));
Time::HiRes::sleep($total);
}
_overprint(_message(10,10,$total));
print "\n";
}
sub _message {
my ($iteration, $total, $time) = @_;
my $message = 'Progress: ['
. q{=} x $iteration
. q{ } x ($total - $iteration)
. '] ';
if (defined $time) {
$message .= sprintf '%0.0fs remaining%25s',
(($total - $iteration) * $time), q{ };
} else {
$message .= '(calculating time remaining)';
}
}
sub _overprint {
my ($message) = @_;
print $message, "\r";
}
#pod =head1 TODO
#pod
#pod =for :list
#pod * allow other divisions of time (other than ten)
#pod
#pod =head1 SEE ALSO
#pod
#pod L<Term::ProgressBar>, L<Term::ProgressBar::Simple>,
#pod L<Progress::Any::Output::TermProgressBarColor>, L<Smart::Comments>
#pod
#pod =cut
"48102931829 minutes remaining";
__END__
=pod
=encoding UTF-8
=head1 NAME
Acme::ProgressBar - a simple progress bar for the patient
=head1 VERSION
version 1.130
=head1 SYNOPSIS
use Acme::ProgressBar;
progress { do_something_slow };
=head1 DESCRIPTION
Acme::ProgressBar provides a simple solution designed to provide accurate
countdowns. No progress bar object needs to be created, and all the
calculation of progress through total time required is handled by the module
itself.
=head1 PERL VERSION
This module is shipped with no promise about what version of perl it will
require in the future. In practice, this tends to mean "you need a perl from
the last three years," but you can't rely on that. If a new version of perl
ship, this software B<may> begin to require it for any reason, and there is no
promise that patches will be accepted to lower the minimum required perl.
=head1 FUNCTIONS
=head2 progress
progress { unlink $_ for <*> };
progress { while (<>) { $ua->get($_) } };
progress { sleep 5; }
There is only one function exported by default, C<progress>. This function
takes a coderef as its lone argument. It will execute this code and display a
simple progress bar indicating the time required for ten iterations through the
code.
=head1 TODO
=over 4
=item *
allow other divisions of time (other than ten)
=back
=head1 SEE ALSO
L<Term::ProgressBar>, L<Term::ProgressBar::Simple>,
L<Progress::Any::Output::TermProgressBarColor>, L<Smart::Comments>
=head1 AUTHOR
Ricardo Signes <cpan@semiotic.systems>
( run in 2.582 seconds using v1.01-cache-2.11-cpan-39bf76dae61 )