calendar.pl 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. #!/usr/bin/perl
  2. # cal.pl - Display the calendar of a given month.
  3. # Fedon Kadifeli, 1998 - April 2003.
  4. # Improved by Trizen - February 2012
  5. my (%months) = (
  6. '1' => {LENGTH => 31, NAME => 'January'},
  7. '2' => {LENGTH => 28, NAME => 'February'},
  8. '3' => {LENGTH => 31, NAME => 'March'},
  9. '4' => {LENGTH => 30, NAME => 'April'},
  10. '5' => {LENGTH => 31, NAME => 'May'},
  11. '6' => {LENGTH => 30, NAME => 'June'},
  12. '7' => {LENGTH => 31, NAME => 'July'},
  13. '8' => {LENGTH => 31, NAME => 'August'},
  14. '9' => {LENGTH => 30, NAME => 'September'},
  15. '10' => {LENGTH => 31, NAME => 'October'},
  16. '11' => {LENGTH => 30, NAME => 'November'},
  17. '12' => {LENGTH => 31, NAME => 'December'},
  18. );
  19. my ($day, $real_month, $real_year) = (localtime time)[3 .. 5];
  20. my ($month, $year) = ($real_month += 1, $real_year += 1900);
  21. if (@ARGV and $ARGV[0] =~ /^(?:\d\d?|\w{3,})$/) {
  22. $month = shift @ARGV;
  23. if ($month =~ /^ *\d\d? *$/) {
  24. unless ($month >= 1 and $month <= 12) {
  25. die "Month must be between 1 and 12!\n";
  26. }
  27. $month = int $month;
  28. }
  29. else {
  30. while (my ($k, $v) = each %months) {
  31. if ($$v{'NAME'} =~ /^\Q$month\E/io) {
  32. $month = $k;
  33. last;
  34. }
  35. }
  36. $month = $real_month unless $month =~ /^\d\d?$/;
  37. }
  38. }
  39. if (@ARGV and $ARGV[0] =~ /^\d\d\d\d$/) {
  40. $year = int shift @ARGV;
  41. }
  42. printf "%*s\n%s\n", 11 + (5 + length($months{$month}{'NAME'})) / 2,
  43. "$months{$month}{'NAME'} $year", 'Su Mo Tu We Th Fr Sa';
  44. if ($year % 400 == 0 or $year % 4 == 0 and $year % 100 != 0) {
  45. $months{'2'}{'LENGTH'} = 29;
  46. }
  47. --$year;
  48. my $st = 1 + $year * 365 + int($year / 4) - int($year / 100) + int($year / 400);
  49. foreach my $i (1 .. $month - 1) {
  50. $st += $months{$i}{'LENGTH'};
  51. }
  52. print q{ } x ($st % 7);
  53. ++$year;
  54. foreach my $i (1 .. $months{$month}{'LENGTH'}) {
  55. if ($i == $day and $year == $real_year and $month == $real_month) {
  56. printf '%s%2d%s ', "\e[7m", $i, "\e[0m";
  57. }
  58. else {
  59. printf '%2d ', $i;
  60. }
  61. print "\n" if ($st + $i) % 7 == 0 and $i != $months{$month}{'LENGTH'};
  62. }
  63. print "\n\n";