8 |
use POSIX qw/strftime/; |
use POSIX qw/strftime/; |
9 |
use File::Slurp; |
use File::Slurp; |
10 |
use Time::HiRes; |
use Time::HiRes; |
11 |
use Data::Dump qw/dump/; |
eval "use Data::Dump qw/dump/;"; |
12 |
|
|
13 |
my $dt = 3; |
my $dt = 3; |
14 |
my $acpi_every = 10; |
my $acpi_every = 10; |
17 |
|
|
18 |
my $debug = shift @ARGV; |
my $debug = shift @ARGV; |
19 |
|
|
20 |
|
my $awesome = 0; |
21 |
|
|
22 |
$|=1; |
$|=1; |
23 |
|
|
24 |
sub proc2hash { |
sub proc2hash { |
58 |
|
|
59 |
find_proc_acpi('battery', sub { |
find_proc_acpi('battery', sub { |
60 |
my $bat = shift; |
my $bat = shift; |
61 |
return unless $bat =~ /BAT/; |
return unless $bat =~ /\w+/; |
62 |
|
|
63 |
warn "# testing battery $bat\n" if ( $debug ); |
warn "# testing battery $bat\n" if ( $debug ); |
64 |
|
|
96 |
|
|
97 |
my $i = 0; |
my $i = 0; |
98 |
|
|
99 |
|
if ( $awesome ) { |
100 |
|
undef $awesome; |
101 |
|
open( $awesome, '|-', 'awesome-client' ) || die "can't open awesome-client: $!"; |
102 |
|
} |
103 |
|
|
104 |
while ( 1 ) { |
while ( 1 ) { |
105 |
my $s = strftime("%Y-%m-%d %H:%M:%S", localtime()); |
my $s = strftime("%Y-%m-%d %H:%M:%S", localtime()); |
106 |
|
|
184 |
my $d_write = ( $d_w - $ld_w ) / $dt; |
my $d_write = ( $d_w - $ld_w ) / $dt; |
185 |
( $ld_r, $ld_w ) = ( $d_r, $d_w ); |
( $ld_r, $ld_w ) = ( $d_r, $d_w ); |
186 |
|
|
187 |
printf("%s | %s |%5s D %-5s|%5s > %-5s| %s%s\n", |
my $out = sprintf("%s | %s |%5s D %-5s|%5s > %-5s| %s%s\n", |
188 |
$s, |
$s, |
189 |
$load, |
$load, |
190 |
unit( $d_read ), unit( $d_write ), |
unit( $d_read ), unit( $d_write ), |
192 |
$bat, $temp, |
$bat, $temp, |
193 |
); |
); |
194 |
|
|
195 |
|
if ( $awesome ) { |
196 |
|
print $awesome "0 statusbar_set_text $out"; |
197 |
|
} else { |
198 |
|
print $out; |
199 |
|
} |
200 |
|
|
201 |
sleep $dt; |
sleep $dt; |
202 |
} |
} |
203 |
|
|