X-Git-Url: https://defaria.com/gitweb/?a=blobdiff_plain;f=maps%2Fbin%2FMAPSUtil.pm;h=2298d77dad0b861c6847054cfcc6c80ae75297ea;hb=95525f583d9d7df558a17b4cae6fbb841701c1be;hp=0d234d2cdc21fedb970e350425a99d0d7ddcc68c;hpb=b0d0e5dbeba3733ba8b8e3dd4235d9ece1082e06;p=clearscm.git diff --git a/maps/bin/MAPSUtil.pm b/maps/bin/MAPSUtil.pm index 0d234d2..2298d77 100644 --- a/maps/bin/MAPSUtil.pm +++ b/maps/bin/MAPSUtil.pm @@ -2,7 +2,7 @@ ################################################################################ # # File: $RCSfile: MAPSUtil.pm,v $ -# Revision: $Revision: 1.1 $ +# Revision: $Revision: 1.1 $ # Description: MAPS Utilities # Author: Andrew@DeFaria.com # Created: Fri Nov 29 14:17:21 2002 @@ -28,65 +28,57 @@ use vars qw (@ISA @EXPORT); UnixDatetime2SQLDatetime ); -# Forwards -sub FormatDate; -sub FormatTime; -sub SQLDatetime2UnixDatetime; -sub SubtractDays; sub Today2SQLDatetime; -sub UnixDatetime2SQLDatetime; sub FormatDate { - my $date = shift; + my ($date) = @_; - return substr ($date, 5, 2) . - "/" . - substr ($date, 8, 2) . - "/" . - substr ($date, 0, 4); + return substr $date, 5, 2 . '/' . + substr $date, 8, 2 . '/' . + substr $date, 0, 4; } # FormatDate sub FormatTime { - my $time = shift; + my ($time) = @_; - my $hours = substr $time, 0, 2; - my $minutes = substr $time, 3, 2; - my $AmPm = $hours > 12 ? "Pm" : "Am"; + my $hours = substr $time, 0, 2; + my $minutes = substr $time, 3, 2; + my $seconds = substr $time, 6, 2; + my $AmPm = $hours > 12 ? 'Pm' : 'Am'; $hours = $hours - 12 if $hours > 12; - return "$hours:$minutes $AmPm"; + return "$hours:$minutes:$seconds $AmPm"; } # FormatTime sub SQLDatetime2UnixDatetime { - my $sqldatetime = shift; + my ($sqldatetime) = @_; my %months = ( - "01" => "Jan", - "02" => "Feb", - "03" => "Mar", - "04" => "Apr", - "05" => "May", - "06" => "Jun", - "07" => "Jul", - "08" => "Aug", - "09" => "Sep", - "10" => "Oct", - "11" => "Nov", - "12" => "Dec" + '01' => 'Jan', + '02' => 'Feb', + '03' => 'Mar', + '04' => 'Apr', + '05' => 'May', + '06' => 'Jun', + '07' => 'Jul', + '08' => 'Aug', + '09' => 'Sep', + '10' => 'Oct', + '11' => 'Nov', + '12' => 'Dec', ); my $year = substr $sqldatetime, 0, 4; my $month = substr $sqldatetime, 5, 2; my $day = substr $sqldatetime, 8, 2; - my $time = FormatTime (substr $sqldatetime, 11); + my $time = FormatTime substr $sqldatetime, 11; return $months {$month} . " $day, $year \@ $time"; } # SQLDatetime2UnixDatetime sub SubtractDays { - my $timestamp = shift; - my $nbr_of_days = shift; + my ($timestamp,$nbr_of_days) = @_; my @months = ( 31, # January @@ -111,11 +103,11 @@ sub SubtractDays { my $days = 0; my $m = 1; - foreach (@months) { + for (@months) { last if $m >= $month; $m++; $days += $_; - } # foreach + } # for # Subtract $nbr_of_days $days += $day - $nbr_of_days; @@ -146,61 +138,57 @@ sub SubtractDays { # Prefix month with 0 if necessary $month++; if ($month < 10) { - $month = "0" . $month; + $month = '0' . $month; } # if # Prefix days with 0 if necessary if ($days eq 0) { - $days = "01"; + $days = '01'; } elsif ($days < 10) { - $days = "0" . $days; + $days = '0' . $days; } # if - return $year . "-" . $month . "-" . $days . substr $timestamp, 10; + return $year . '-' . $month . '-' . $days . substr $timestamp, 10; } # SubtractDays -sub Today2SQLDatetime { - return UnixDatetime2SQLDatetime (scalar (localtime)); -} # Today2SQLDatetime - sub UnixDatetime2SQLDatetime { my $datetime = shift; my $orig_datetime = $datetime; my %months = ( - "Jan" => "01", - "Feb" => "02", - "Mar" => "03", - "Apr" => "04", - "May" => "05", - "Jun" => "06", - "Jul" => "07", - "Aug" => "08", - "Sep" => "09", - "Oct" => "10", - "Nov" => "11", - "Dec" => "12" + 'Jan' => '01', + 'Feb' => '02', + 'Mar' => '03', + 'Apr' => '04', + 'May' => '05', + 'Jun' => '06', + 'Jul' => '07', + 'Aug' => '08', + 'Sep' => '09', + 'Oct' => '10', + 'Nov' => '11', + 'Dec' => '12', ); # Some mailers neglect to put the leading day of the week field in. # Check for this and compensate. my $dow = substr $datetime, 0, 3; - if ($dow ne "Mon" && - $dow ne "Tue" && - $dow ne "Wed" && - $dow ne "Thu" && - $dow ne "Fri" && - $dow ne "Sat" && - $dow ne "Sun") { - $datetime = "XXX, " . $datetime; + if ($dow ne 'Mon' && + $dow ne 'Tue' && + $dow ne 'Wed' && + $dow ne 'Thu' && + $dow ne 'Fri' && + $dow ne 'Sat' && + $dow ne 'Sun') { + $datetime = 'XXX, ' . $datetime; } # if # Some mailers have day before month. We need to correct this my $day = substr $datetime, 5, 2; if ($day =~ /\d /) { - $day = "0" . (substr $day, 0, 1); + $day = '0' . (substr $day, 0, 1); $datetime = (substr $datetime, 0, 5) . $day . (substr $datetime, 6); } # if @@ -209,8 +197,8 @@ sub UnixDatetime2SQLDatetime { } # if # Check for 1 digit date - if ((substr $day, 0, 1) eq " ") { - $day = "0" . (substr $day, 1, 1); + if ((substr $day, 0, 1) eq ' ') { + $day = '0' . (substr $day, 1, 1); $datetime = (substr $datetime, 0, 8) . $day . (substr $datetime, 10); } # if @@ -224,9 +212,9 @@ sub UnixDatetime2SQLDatetime { } # if # Check for 2 digit year. Argh! - if (length $year == 2 or (substr $year, 2, 1) eq " ") { - $year = "20" . (substr $year, 0, 2); - $datetime = (substr $datetime, 0, 12) . "20" . (substr $datetime, 12); + if (length $year == 2 or (substr $year, 2, 1) eq ' ') { + $year = '20' . (substr $year, 0, 2); + $datetime = (substr $datetime, 0, 12) . '20' . (substr $datetime, 12); } # if my $month_name = substr $datetime, 4, 3; @@ -262,4 +250,8 @@ sub UnixDatetime2SQLDatetime { return "$year-$month-$day $time"; } # UnixDatetime2SQLDatetime +sub Today2SQLDatetime { + return UnixDatetime2SQLDatetime scalar localtime; +} # Today2SQLDatetime + 1;