X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;ds=inline;f=perl%2Fjulian.pm;fp=perl%2Fjulian.pm;h=c5cf43c87d8e699bc9d5487d21b2d14ebcedf2ec;hb=6f566611af29f5c7af653abf8cec2760a0c25b6e;hp=0000000000000000000000000000000000000000;hpb=15c6f0c107d136f8366bca25e3dcb7d14f2ed24b;p=spider.git diff --git a/perl/julian.pm b/perl/julian.pm new file mode 100644 index 00000000..c5cf43c8 --- /dev/null +++ b/perl/julian.pm @@ -0,0 +1,117 @@ +# +# various julian date calculations +# +# Copyright (c) - 1998 Dirk Koopman G1TLH +# +# $Id$ +# + +package julian; + +use FileHandle; +use DXDebug; + +use strict; + +my @days = (31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31); + +# take a unix date and transform it into a julian day (ie (1998, 13) = 13th day of 1998) +sub unixtoj +{ + my ($pkg, $t) = @_; + my ($day, $mon, $year) = (gmtime($t))[3..5]; + my $jday; + + # set the correct no of days for february + if ($year < 100) { + $year += ($year < 50) ? 2000 : 1900; + } + $days[1] = isleap($year) ? 29 : 28; + for (my $i = 0, $jday = 0; $i < $mon; $i++) { + $jday += $days[$i]; + } + $jday += $day; + return ($year, $jday); +} + +# take a julian date and subtract a number of days from it, returning the julian date +sub sub +{ + my ($pkg, $year, $day, $amount) = @_; + my $diny = isleap($year) ? 366 : 365; + $day -= $amount; + while ($day <= 0) { + $day += $diny; + $year -= 1; + $diny = isleap($year) ? 366 : 365; + } + return ($year, $day); +} + +sub add +{ + my ($pkg, $year, $day, $amount) = @_; + my $diny = isleap($year) ? 366 : 365; + $day += $amount; + while ($day > $diny) { + $day -= $diny; + $year += 1; + $diny = isleap($year) ? 366 : 365; + } + return ($year, $day); +} + +sub cmp +{ + my ($pkg, $y1, $d1, $y2, $d2) = @_; + return $d1 - $d2 if ($y1 == $y2); + return $y1 - $y2; +} + +# is it a leap year? +sub isleap +{ + my $year = shift; + return ($year % 4 == 0 && ($year % 100 != 0 || $year % 400 == 0)) ? 1 : 0; +} + +# open a data file with prefix $fn/$year/$day.dat and return an object to it +sub open +{ + my ($name, $pkg, $fn, $year, $day, $mode) = @_; + + # if we are writing, check that the directory exists + if (defined $mode) { + my $dir = "$fn/$year"; + mkdir($dir, 0777) if ! -e $dir; + } + my $self = {}; + $self->{fn} = sprintf "$fn/$year/%03d.dat", $day; + $mode = 'r' if !$mode; + my $fh = new FileHandle $self->{fn}, $mode; + return undef if !$fh; + $fh->autoflush(1) if $mode ne 'r'; # make it autoflushing if writable + $self->{fh} = $fh; + $self->{year} = $year; + $self->{day} = $day; + dbg("julian", "opening $self->{fn}\n"); + + return bless $self, $pkg; +} + +# close the data file +sub close +{ + my $self = shift; + undef $self->{fh}; # close the filehandle + delete $self->{fh}; +} + +sub DESTROY # catch undefs and do what is required further do the tree +{ + my $self = shift; + dbg("julian", "closing $self->{fn}\n"); + undef $self->{fh} if defined $self->{fh}; +} + +1;