--- trunk/dwm-status.pl 2009/06/19 14:40:14 115 +++ trunk/dwm-status.pl 2010/03/31 06:55:19 135 @@ -16,7 +16,8 @@ my $disk_blk_size = 512; my $debug = shift @ARGV; -my $awesome = 3; +my $awesome = 0; +my $dzen = 1; $|=1; @@ -67,8 +68,16 @@ } }); +my $unit_colors = { + 'b' => '#ff0000', + 'k' => '#ffff00', + 'M' => '#00ff00', + 'G' => '#0000ff', +}; + sub unit { - my $v = shift; + my ($v,$align) = @_; + $align ||= ''; warn "unit( $v )\n" if ($debug); @@ -80,13 +89,24 @@ $v /= 1024; } + my $unit = $units[$o]; + + my $out = ''; + $out .= '^fg(' . $unit_colors->{$unit} . ')'; + if ( $v >= 1 ) { - return sprintf("%d%s", $v, $units[$o]); + $out .= sprintf("%${align}5d",$v); } elsif ( $v == 0 ) { - return ''; + $out = ' ' x 5; } else { - return sprintf("%.1f%s", $v, $units[$o]); + $out .= sprintf("%${align}5.1f", $v); } + + $unit = '^fg(#444444)' . $unit if $dzen; + $out =~ s/\s(\s*)$/$unit$1/ unless $out =~ m/\s{5}/; + $out .= '^fg(#ffffff)' if $dzen; + + return $out; } my ( $lrx, $ltx ) = ( 0, 0 ); @@ -106,7 +126,7 @@ my $full = read_file( $sysfs_path ); $sysfs_path =~ s/_full/_now/; my $now = read_file( $sysfs_path ); - $bat = sprintf("%2d%% | ", $now * 100 / $full ); + $bat = sprintf("%2d%%", $now * 100 / $full ); } elsif ( $proc_acpi_battery ) { @@ -126,15 +146,13 @@ my $mm = int( ( $time - $hh ) * 60 ); my $ss = ( $time * 3600 ) % 60; - $bat = sprintf("%s %2d%% %02d:%02d:%02d %3.1fW!| ", + $bat = sprintf("%s %2d%% %02d:%02d:%02d %3.1fW!", substr($state->{'charging state'},0,1), $pcnt * 100, $hh, $mm, $ss, $state->{'present rate'} / 1000 ); } } - } else { - $bat =~ s/!(\|\s)$/ $1/; } $i++; @@ -187,14 +205,15 @@ my $d_write = ( $d_w - $ld_w ) / $dt; ( $ld_r, $ld_w ) = ( $d_r, $d_w ); - my $out = sprintf("%s | %s |%5s D %-5s|%5s > %-5s| %s%s", - $s, + my $out = join( $dzen ? ' ^fg(#333333)|^fg(#ffffff) ' : ' | ', $load, - unit( $d_read ), unit( $d_write ), - unit( $net_rx ), unit( $net_tx ), + unit( $d_read ) . ' D ' . unit( $d_write, '-' ), + unit( $net_rx ) . ' > ' . unit( $net_tx, '-' ), $bat, $temp, + $s, ); + print "$out\n"; if ( $awesome ) { open(my $fh, '|-', 'awesome-client') || die "can't pipe to awesome-client: $!";