|
|
| version 1.18, 2015/05/07 12:31:43 | version 1.21, 2015/10/26 14:25:40 |
|---|---|
| Line 2 | Line 2 |
| ############################################################################### | ############################################################################### |
| # $Log$ | # $Log$ |
| # Revision 1.21 2015/10/26 14:25:40 nick | |
| # Fixed a bug that was improperly including the day of week string preventing the weekend comics from fetching proproperly. | |
| # | |
| # Revision 1.20 2015/10/22 12:58:44 nick | |
| # Added the ability for Sunday only comics. Stonesoup is no longer weekdays, this has been added to Sunday only. I also added Foxtrot Classics for weekdays and Foxtrot for Sundays. | |
| # | |
| # Revision 1.19 2015/07/13 12:56:58 nick | |
| # Added Sally Forth and Pearls Before Swine. Adding Sally Forth required a change in the 'wget' command for fetching the index file to include 'user-agent' and 'referer'. | |
| # | |
| # Revision 1.18 2015/05/07 12:31:43 nick | # Revision 1.18 2015/05/07 12:31:43 nick |
| # Added favicon | # Added favicon |
| # | # |
| Line 22 use Data::Dumper; | Line 31 use Data::Dumper; |
| use Pod::Usage; | use Pod::Usage; |
| use Getopt::Long; | use Getopt::Long; |
| use Date::Calc qw/Date_to_Text_Long Today/; | use Date::Calc qw/Date_to_Text_Long Today Day_of_Week Day_of_Week_to_Text/; |
| ## | ## |
| ## Some default values | ## Some default values |
| Line 51 print STDOUT "Starting comic fetch at $D | Line 60 print STDOUT "Starting comic fetch at $D |
| &writeTitle ( \%dates ); | &writeTitle ( \%dates ); |
| foreach my $comic ( sort keys %comics ) { | foreach my $comic ( sort keys %comics ) { |
| ## Skip if this is Sunday and the comic is weekdays only | |
| next if ( $comic =~ m/config/ ); | next if ( $comic =~ m/config/ ); |
| if ( ( $dates{'day2'} eq "Sunday" ) && | if (($dates{'wday'} eq "Sunday") && |
| ( $comics{$comic}{'sunday'} == 0 ) ) { print "Skipping.\n"; next; } | ($comics{$comic}{'sunday'} == 0)) { |
| print "Skipping '$comic'; Weekdays only.\n"; | |
| next; | |
| } | |
| ## Skip if Sunday only comic and it's not Sunday. | |
| if (($dates{'wday'} ne "Sunday") && | |
| ($comics{$comic}{'sunday_only'} == 1)) { | |
| print "Skipping '$comic' ($comics{$comic}{'sunday_only'}); Sunday only.\n"; | |
| next | |
| } | |
| $comics{$comic}{'error'} = &downloadComic ( \%comics, $comic, \%dates ); | $comics{$comic}{'error'} = &downloadComic ( \%comics, $comic, \%dates ); |
| &writeComic ( \%comics, $comic, \%dates ); | &writeComic ( \%comics, $comic, \%dates ); |
| Line 69 foreach my $comic ( sort keys %comics ) | Line 91 foreach my $comic ( sort keys %comics ) |
| } | } |
| close(IMG); | close(IMG); |
| system( "/usr/bin/convert -resize 640 $file $file" ) | system( "/usr/bin/convert -resize 640 $file $file" ) |
| if ( $size > 640 ) | if ( $size > 640 ) |
| } | } |
| Line 134 sub readComicConfig ($$) { | Line 157 sub readComicConfig ($$) { |
| $comicConfig{$res[0]}{'mode'} = $res[3]; | $comicConfig{$res[0]}{'mode'} = $res[3]; |
| $comicConfig{$res[0]}{'fullName'} = $res[4]; | $comicConfig{$res[0]}{'fullName'} = $res[4]; |
| $comicConfig{$res[0]}{'ext'} = $res[5]; | $comicConfig{$res[0]}{'ext'} = $res[5]; |
| $comicConfig{$res[0]}{'sunday'} = $res[6] || 1; | $comicConfig{$res[0]}{'sunday'} = sprintf("%d", $res[6] || 1); |
| $comicConfig{$res[0]}{'sunday_only'} = sprintf("%d", $res[7] || 0); | |
| $comicConfig{$res[0]}{'error'} = 0; | $comicConfig{$res[0]}{'error'} = 0; |
| } | } |
| elsif ( $_ =~ m/(.*)\s+=\s+(.*)/ ) { | elsif ( $_ =~ m/(.*)\s+=\s+(.*)/ ) { |
| Line 301 sub indexDownload ($$) { | Line 325 sub indexDownload ($$) { |
| my ( @lines, $comicLine, $mainURL ); | my ( @lines, $comicLine, $mainURL ); |
| my $comicIndex = "indexes/index.$comic"; | my $comicIndex = "indexes/index.$comic"; |
| `wget -q $comics->{$comic}{'url'} -O $comicIndex`; | my $wget_cmd = "wget -q --referer=\"$comics->{$comic}{'url'}\" " . |
| "--user-agent=\"$USER_AGENT\" " . | |
| "$comics->{$comic}{'url'} -O $comicIndex"; | |
| system($wget_cmd); | |
| if ( ! open FILEN, "<$comicIndex" ) { | if ( ! open FILEN, "<$comicIndex" ) { |
| return "ERROR: Can't open index file for " . $comics->{$comic}{'fullName'} . | return "ERROR: Can't open index file for " . $comics->{$comic}{'fullName'} . |
| Line 375 sub fetchDates () { | Line 402 sub fetchDates () { |
| $dates{'day2'} = ( $dates{'day'} < 10 ) ? "0" . $dates{'day'} : $dates{'day'}; | $dates{'day2'} = ( $dates{'day'} < 10 ) ? "0" . $dates{'day'} : $dates{'day'}; |
| $dates{'mon'}++; | $dates{'mon'}++; |
| $dates{'mon2'} = ( $dates{'mon'} < 10 ) ? "0".$dates{'mon'} : $dates{'mon'}; | $dates{'mon2'} = ( $dates{'mon'} < 10 ) ? "0".$dates{'mon'} : $dates{'mon'}; |
| my @days = qw/ Sunday Monday Tuesday Wednesday Thursday Friday Saturday /; | |
| $dates{'wday'} = $days[$dates{'dow'}]; | |
| return %dates; | return %dates; |
| } | } |