Date::ManipX::Almanac::Date - Methods for working with almanac dates
use Date::ManipX::Almanac::Date my $dmad = Date::ManipX::Almanac::Date->new(); $dmad->config( latitude => 38.8987, # Degrees; south is negative longitude => -77.0377, # Degrees; west is negative elevation => 17, # Meters, defaults to 0 name => 'White House', # Optional ); $dmad->parse( 'sunrise today' ); $dmad->printf( 'Sunrise on %d-%b-%Y is %H:%M:%S' );
This Perl module implements a version of Date::Manip::Date that can parse a selection of almanac events. These are implemented using the relevant Astro::Coord::ECI classes.
This module is not an actual subclass of Date::Manip::Date, but holds a Date::Manip::Date object to perform a lot of the heavy lifting, and implements all its public methods, usually by delegating directly to Date::Manip::Date. This implementation was chosen because various portions of the Date::Manip::Date interface want an honest-to-God Date::Manip::Date object, not a subclass. The decision to implement this way may be revisited if the situation warrants.
Date::Manip::Date
In the meantime, be aware that if you are doing something like instantiating a Date::Manip::TZ from this object, you will have to use $dmad->dmd(), not $dmad.
$dmad->dmd()
$dmad
Note that most almanac calculations are for a specific point on the Earth's surface. It would be nice to default this via the computer's geolocation API, but for at least the immediate future you must specify it explicitly. Failure to do this will result in an exception from parse() or parse_time() if an almanac event was actually specified.
The functional interface to Date::Manip::Date is not implemented. Neither is Date::Manip::DM5 functionality.
This class provides the following public methods which are either in addition to those provided by Date::Manip::Date or provide additional functionality. Any Date::Manip::Date methods not mentioned below should Just Work.
my $dmad = Date::ManipX::Almanac::Date->new();
The arguments are the same as the Date::Manip::Date new() arguments, but CONFIGURATION items specific to this class are supported.
new()
my $dmad_2 = $dmad->new_date();
The arguments are the same as the Date::Manip::Date new_date() arguments, but CONFIGURATION items specific to this class are supported.
new_date()
my $dmad = Date::ManipX::Almanac::Date->new_config();
The arguments are the same as the Date::Manip::Date new_config() arguments, but CONFIGURATION items specific to this class are supported.
new_config()
If the first argument is a Date::ManipX::Almanac::Date object, it is replaced by the underlying Date::Manip::Date object.
Date::ManipX::Almanac::Date
my $err = $dmad->config( ... );
All Date::Manip::Date arguments are supported, plus those described under CONFIGURATION, below.
my $dmd = $dmad->dmd();
This method returns the underlying Date::Manip::Date object.
This method returns a description of the most-recent error, or a false value if there is none. Errors detected in this package trump those in Date::Manip::Date.
my @config = $dmad->get_config( ... );
my $err = $dmad->parse( 'today sunset' );
All Date::Manip::Date strings are supported, plus those described under ALMANAC EVENTS in Date::ManipX::Almanac::Lang.
my $err = $dmad->parse_time( 'sunset' );
This class uses the Date::Manip config() interface, but adds or modifies the following configuration items:
config()
This specifies a configuration file. This is formatted like a Date::Manip file, but can not have sections or any of the configuration items allowed in them. A Date::Manip-style section definition is treated as end-of-file, with a warning. This means you can not use AlmanacConfigFile to define holidays or events.
AlmanacConfigFile
On the other hand, it can have any configuration items valid for this class, plus any valid in the top section of a Date::Manip configuration file.
Specifically, you can include other configuration files, via either AlmanacConfigFile or ConfigFile. Files included by ConfigFile can include anything a Date::Manip config file can (including event and holiday sections), but nothing specific to Date::ManipX::Almanac.
ConfigFile
This only modifies the embedded Date::Manip::Date object, though after all the dust settles the language of the embedded object is retrieved.
Caveat: It appears to be a restriction in Date::Manip::Date that if you configure (at least) Language after configuring a ConfigFile, any events and/or holidays configured by the nested file will not be retained. This makes sense when you think about it, because if you configure
December 25 = Christmas
and then change the language to Spanish, you still can't say 'mediodia Navidad' unless you load a new holiday definition that supports this.
'mediodia Navidad'
In addition to its action on the superclass, this clears the location, and populates the sky with Astro::Coord::ECI::Sun and Astro::Coord::ECI::Moon.
This specifies the elevation of the location, in meters above sea level.
This specifies the latitude of the location, in degrees north (positive) or south (negative) of the Equator.
In addition to its action on the superclass, this loads the almanac event definitions for the specified language. Note that this will fail unless a Date::ManipX::Almanac::Lang subclass has been implemented for the language.
This specifies the location for which to compute the almanac. This can be specified as an Astro::Coord::ECI object, or undef to clear the location. Setting or clearing this also sets or clears Elevation, Latitude, Longitude, and Name.
undef
This specifies the longitude of the location, in degrees east (positive) or west (negative) of Greenwich.
This specifies the name of the location. The name is used for display only, and is optional.
This can be specified as:
undef or the empty string ('' ).
''
The previously-configured sky is cleared.
An Astro::Coord::ECI object (or subclass).
This is appended to the configured objects in the sky.
The name of an Astro::Coord::ECI class.
This class is instantiated, and the resultant object appended to the configured objects in the sky.
In general, you can only usefully specify objects this way if they can be instantiated by a call to new(), without arguments.
But there is a special case for Astro::Coord::ECI::Star. These can be specified by appending name, right ascension (in h:m:s), declination (in degrees), and optionally range in parsecs. The appended fields are parsed using Text::ParseWords::shellwords(), so star names containing spaces can be either quoted (e.g. 'Deneb Algedi') or reverse-solidus-escaped (e.g. Cor\ Caroli).
Text::ParseWords::shellwords()
'Deneb Algedi'
Cor\ Caroli
A reference to an array of the above
The contents of the array replace the previously-configured sky.
This specifies how far the Sun is below the horizon at the beginning or end of twilight. You can specify this in degrees, or as one of the following strings for convenience: 'civil' (6 degrees); 'nautical' (12 degrees); or 'astronomical' (18 degrees).
'civil'
'nautical'
'astronomical'
The default is civil twilight.
Date::Manip::Date.
Support is by the author. Please file bug reports at https://rt.cpan.org/Public/Dist/Display.html?Name=Date-ManipX-Astro-Base, https://github.com/trwyant/perl-Date-ManipX-Astro-Base/issues/, or in electronic mail to the author.
Thomas R. Wyant, III wyant at cpan dot org
Copyright (C) 2021 by Thomas R. Wyant, III
This program is free software; you can redistribute it and/or modify it under the same terms as Perl 5.10.0. For more details, see the full text of the licenses in the directory LICENSES.
This program is distributed in the hope that it will be useful, but without any warranty; without even the implied warranty of merchantability or fitness for a particular purpose.
To install Date::ManipX::Almanac, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Date::ManipX::Almanac
CPAN shell
perl -MCPAN -e shell install Date::ManipX::Almanac
For more information on module installation, please visit the detailed CPAN module installation guide.