X-Git-Url: https://defaria.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=bin%2Fsetbg;h=981c77f2cdc529c49c42d1354ddf69920b5f4bfc;hb=a5e947bf363fa107c5f7de50e6334ddcec415eb0;hp=39ce45bf53eb5506c22ed33ebf1984a433595485;hpb=78865a3b920fa9681f16285ae96f2ffe9af0d12f;p=clearscm.git diff --git a/bin/setbg b/bin/setbg index 39ce45b..981c77f 100755 --- a/bin/setbg +++ b/bin/setbg @@ -57,17 +57,22 @@ use warnings; use FindBin; use Getopt::Long; use Proc::ProcessTable; +use File::Spec; use CGI qw/:standard/; use lib "$FindBin::Bin/../lib"; +use DateUtils; use Display; +use Logger; use Utils; my $VERSION = '$Revision: 1.10 $'; ($VERSION) = ($VERSION =~ /\$Revision: (.*) /); my $processes = new Proc::ProcessTable; +my @imgDirs; +my %totals; foreach my $process (@{$processes->table}) { if ($process->cmndline =~ /setbg/ and @@ -78,70 +83,126 @@ foreach my $process (@{$processes->table}) { } # if } # foreach +sub displayStats () { + my $statsFile = Logger->new( + name => ".$FindBin::Script.stats", + path => $ENV{HOME}, + extension => '', + ); + + $statsFile->log('At ' . localtime()); + + Stats \%totals, $statsFile; + + return; +} # displayStats + +sub fillPictures () { + my @images; + + foreach (@imgDirs) { + my @pics = `find "$_" -type f -name "*.jpg"`; + + chomp @pics; + push @images, @pics; + } # foreach + + $totals{images} = scalar @images; + + displayStats; + + return @images; +} # fillPictures + +sub updateSetBG ($) { + my ($image) = @_; + + open my $log, '>', "$ENV{HOME}/.$FindBin::Script" + or error "Unable to open $ENV{HOME}/.$FindBin::Script for writing - $!", 1; + + display $image, $log; + + close $log; + + open $log, '>>', "$ENV{HOME}/.$FindBin::Script.hist" + or error "Unable to open $ENV{HOME}/.$FindBin::Script.hist for append - $!", 1; + + my $msg = localtime() . ":$image"; + + display $msg, $log; + + close $log; + + return; +} # updateSetBG + $0 = "$FindBin::Script " . join ' ', @ARGV; verbose "$FindBin::Script v$VERSION"; my $sleep = 60 * 60; -my @imgDir; GetOptions ( 'usage' => sub { Usage }, 'verbose' => sub { set_verbose }, 'debug' => sub { set_debug }, 'sleep=i' => \$sleep, - 'bgdir=s' => \@imgDir, + 'bgdir=s' => \@imgDirs, ) || Usage; -foreach (@imgDir) { - error "$_ is not a directory", 1 unless -d $_; +for (my $i = 0; $i < scalar @imgDirs; $i++) { + error "$imgDirs[$i] is not a directory", 1 unless -d $imgDirs[$i]; + + $imgDirs[$i] = File::Spec->rel2abs ($imgDirs[$i]); } # foreach # Using gsettings -my $setbg = "gsettings"; -my $setbgOpts = "set org.gnome.desktop.background picture-uri \"file://"; +my $setbg = "gsettings"; +my $setbgOpts= "set org.gnome.desktop.background picture-uri \"file://"; -my @images; +my @images = fillPictures; -foreach (@imgDir) { - my @pics = `find "$_" -type f -name "*.jpg"`; - chomp @pics; - push @images, @pics; -} # foreach +Usage "No images to display. Must specify -bgdir" unless @images; -Usage "No images to display. Must specify -imgDir" unless @images; - sub SwitchWallPaper { # We don't need to do anything here, just handle the interrupt and # let the while loop continue. debug 'SwitchWallPaper: Interrupt received'; + displayStats; } # SwitchWallPaper $SIG{USR2} = \&SwitchWallPaper; +$SIG{USR1} = \&fillPictures; my $debugger = $DB::OUT; +my $today; + +truncate "$ENV{HOME}/.$FindBin::Script.hist", 0; EnterDaemonMode unless defined $DB::OUT; while () { my $image = escapeHTML ($images[int (rand $#images)]); - open my $log, '>', "$ENV{HOME}/.$FindBin::Script" - or error "Unable to open $ENV{HOME}/.setbg for writing - $!", 1; - - display $image, $log; - my $cmd = "$setbg $setbgOpts$image\" 2> /dev/null"; my @output = `$cmd`; if ($? != 0) { - display "ERROR Trying to set background - command used \"$cmd\"", $log; - display "Output:"; - display join "\n", @output, $log; + error "Trying to set background - command used \"$cmd\"\n\nOutput\n\n" . + join "\n", @output; + $totals{errors}++; + } else { + $totals{'Images displayed'}++; + + updateSetBG $image; } # if - - close $log; - + + $today = YMD; + sleep $sleep; + + if ($today ne YMD){ + @images = fillPictures; + } # if } # while