8 |
use POSIX qw/strftime/; |
use POSIX qw/strftime/; |
9 |
use File::Slurp; |
use File::Slurp; |
10 |
use Time::HiRes; |
use Time::HiRes; |
11 |
eval { |
use Data::Dump qw/dump/; |
|
use Data::Dump qw/dump/; |
|
|
}; |
|
12 |
|
|
13 |
my $dt = 3; |
my $dt = 3; |
14 |
my $acpi_every = 10; |
my $acpi_every = 10; |
16 |
my $disk_blk_size = 512; |
my $disk_blk_size = 512; |
17 |
|
|
18 |
my $debug = shift @ARGV; |
my $debug = shift @ARGV; |
19 |
|
my $awesome = 1; |
20 |
|
|
21 |
$|=1; |
$|=1; |
22 |
|
|
57 |
|
|
58 |
find_proc_acpi('battery', sub { |
find_proc_acpi('battery', sub { |
59 |
my $bat = shift; |
my $bat = shift; |
60 |
return unless $bat =~ /BAT/; |
return unless $bat =~ /\w+/; |
61 |
|
|
62 |
warn "# testing battery $bat\n" if ( $debug ); |
warn "# testing battery $bat\n" if ( $debug ); |
63 |
|
|
95 |
|
|
96 |
my $i = 0; |
my $i = 0; |
97 |
|
|
98 |
|
|
99 |
while ( 1 ) { |
while ( 1 ) { |
100 |
my $s = strftime("%Y-%m-%d %H:%M:%S", localtime()); |
my $s = strftime("%Y-%m-%d %H:%M:%S", localtime()); |
101 |
|
|
179 |
my $d_write = ( $d_w - $ld_w ) / $dt; |
my $d_write = ( $d_w - $ld_w ) / $dt; |
180 |
( $ld_r, $ld_w ) = ( $d_r, $d_w ); |
( $ld_r, $ld_w ) = ( $d_r, $d_w ); |
181 |
|
|
182 |
printf("%s | %s |%5s D %-5s|%5s > %-5s| %s%s\n", |
my $out = sprintf("%s | %s |%5s D %-5s|%5s > %-5s| %s%s\n", |
183 |
$s, |
$s, |
184 |
$load, |
$load, |
185 |
unit( $d_read ), unit( $d_write ), |
unit( $d_read ), unit( $d_write ), |
187 |
$bat, $temp, |
$bat, $temp, |
188 |
); |
); |
189 |
|
|
190 |
|
print $out; |
191 |
|
if ( $awesome ) { |
192 |
|
open(my $fh, '|-', 'awesome-client') || die "can't pipe to awesome-client: $!"; |
193 |
|
print $fh "0 widget_tell dwm-status $out\n"; |
194 |
|
close($fh); |
195 |
|
} |
196 |
|
|
197 |
sleep $dt; |
sleep $dt; |
198 |
} |
} |
199 |
|
|