NAME

Astro::App::Satpass2::FormatValue - Format Astro::App::Satpass2 output as text.

SYNOPSIS

 use strict;
 use warnings;
 
 use Astro::App::Satpass2::FormatValue;
 use Astro::Coord::ECI;
 use Astro::Coord::ECI::Moon;
 use Astro::Coord::ECI::Sun;
 use Astro::Coord::ECI::Utils qw{ deg2rad };
 
 my $time = time();
 my $moon = Astro::Coord::ECI::Moon->universal( $time );
 my $sun = Astro::Coord::ECI::Sun->universal( $time );
 my $station = Astro::Coord::ECI->new(
     name => 'White House',
 )->geodetic(
     deg2rad(38.8987),  # latitude
     deg2rad(-77.0377), # longitude
     17 / 1000);	# height above sea level, Km
 
 foreach my $body ( $sun, $moon ) {
     my $fmt = Astro::App::Satpass2::FormatValue->new(
	 data => {
	     body => $body,
	     station => $station,
	     time => $time,
	 } );
     print join( ' ', $fmt->date(), $fmt->time(),
	 $fmt->name( width => 10 ),
	 $fmt->azimuth( bearing => 2 ),
	 $fmt->elevation() ), "\n";
 }

DETAILS

This class is intended to take care of the details of performing field formatting for an Astro::App::Satpass2::Format object, and was actually written to format data for Template-Toolkit. It is not intended to be used outside one of these, though I suppose it could be.

This class is intended to be initialized with a hash containing data in known locations. Not coincidentally, the hash corresponds to the hashes produced by methods of interest in Astro::Coord::ECI and its subclasses.

METHODS

This class supports the following public methods.

Instantiator

new

$fmt = Astro::App::Satpass2::FormatValue->new();

This static method instantiates a new value formatter. It takes as arguments name/value pairs.

Because this class has no mutators you must give it all the information it needs to do its job when you instantiate it.

The following argument names are recognized:

data

This argument is a hash containing the data to be displayed. The keys in the hash are accessed by the various transformation and formatter methods. This argument is technically optional, but unless you have specified title => 1 (which see) you will not get a very useful object if you omit it.

If this hash contains a {time} key, the Astro::Coord::ECI objects in the {body} and {station} keys (if any) will be set to that value.

date_format

This argument is the string that the time_formatter will use to format dates. It is assumed that this format will not produce any time information, though this is not enforced. The default is whatever the default date format is for the time_formatter.

default

This optional argument is a hash used to override the defaults for the various formatters. The keys are formatter names, and the values of those keys are hashes containing the specific argument defaults.

desired_equinox_dynamical

This optional argument is the desired equinox in dynamical time. If specified as a non-zero Perl time, inertial coordinates will be precessed to this equinox. The default is 0.

fixed_width

This optional argument specifies whether or not fixed-width fields are to be produced. If true (the default) numeric default widths are applied where needed. If false the default width is '', which is the convention for variable-width fields.

list_formatter

This optional argument provides the implementation of the list() formatter method. If you provide a defined value it must be a code reference. The code reference will be called with the same arguments as were used for local_coord(), including the invocant.

local_coordinates

This optional argument provides the implementation of the local_coord() formatter method. You can provide either a code reference of one of the following strings:

az_rng --------- Azimuth and range;
azel ----------- Elevation and azimuth;
azel_rng ------- Elevation, azimuth and range;
equatorial ----- Right ascension and declination;
equatorial_rng - Right ascension, declination, and range.

The code reference will be called with the same arguments as were used for local_coord(), including the invocant.

The default is azel_rng.

overflow

If this optional argument is true (in the Perl sense, i.e. anything but undef, 0, or '') fields will be allowed to overflow their widths. If false (the default) too-long strings will be truncated on the right, and too-long numeric fields will generally be *-filled.

report

This optional argument is the name of the report being produced (e.g. 'pass', 'flare', or whatever). If specified, format effectors will use this for report-specific localization of titles, missing data text, and literals.

The localization will come from key {"-$report"}{string}{$string}, where $report is the value of this argument, and $string is the string being localized.

time_format

This argument is the string that the time_formatter will use to format times of day. It is assumed that this format will not produce any date information, though this is not enforced. The default is whatever the default time format is for the time_formatter.

time_formatter

This argument is either the name or an instance of an Astro::App::Satpass2::FormatTime subclass. This object is used to format times. The default is Astro::App::Satpass2::FormatTime.

title

If this argument is true, the formatter methods will produce titles rather than values. In this case the data hash is unused. The default is false.

title_gravity

This argument specifies the value for the title_gravity attribute. See the title_gravity() documentation for full details.

warner

This optional argument must be an instance of Astro::App::Satpass2::Warner. If not provided, a new Warner object will be instantiated.

Accessors

These are kept to a minimum, since the main purpose of the object is to provide formatting.

body

$fmt->body();

This accessor returns the contents of the {body} key of the original hash passed to the data argument when the object was instantiated. It returns a false value if the {body} key exists but is not an Astro::Coord::ECI|Astro::Coord::ECI, or if the key does not exist.

This accessor exists because the Astro::App::Satpass2::Format::Template list() method needs to look at the body to decide what to display.

Mutators

These also are kept to a minimum.

If called without an argument, all mutators act as accessors, and return the value of the attribute.

If called with an argument, they change the attribute (or croak if the new value is invalid), and return their invocant.

fixed_width

$fmt->fixed_width( 0 );
say 'Fixed-width formatting is ',
   $fmt->fixed_width() ? 'on' : 'off';

If false, this boolean attribute causes all widths not explicitly specified to default to '', which is the convention for non-fixed-width fields. It can also be set via the fixed_width argument to new(). The default is 1 (i.e. true).

If called without an argument, this method acts as an accessor, returning the current value.

This boolean attribute has a mutator because Template-Toolkit needs to modify it, and Template-Toolkit-style named arguments can't be used for clone() because of the way the interface is designed.

title_gravity

$fmt->title_gravity( 'bottom' );
say 'Title gravity is ', $fmt->title_gravity();

This attribute specifies how multiline titles are aligned. The possible values are 'top' or 'bottom'. The manifest constants TITLE_GRAVITY_TOP and TITLE_GRAVITY_BOTTOM are defined to represent these, but they are not exported.

If you specify 'bottom', you get an extra empty line above the titles. This is an annoying behavior necessitated by the fact that the first line of the first title has to be inserted into the output before we know how many lines are needed to print all the titles. So we force an extra line with blanks to get the process rolling.

This hack means that you do not want to use 'bottom' unless you intend to actually display all the lines of each title.

The default is 'top'.

This attribute has a mutator because Template-Toolkit needs to modify it.

Transformations

Some of the methods of interest produce hashes that contain supplementary data. For example, the output of the Astro::Coord::ECI::TLE pass() method may contain an <{appulse}> key describing the appulsed body. These methods give access to such data. If the requested data exists, they typically return an Astro::App::Satpass2::FormatValue object, though they may return a reference to an array of them, or to an iterator function. If the requested data do not exist, they typically return undef.

appulse

my $apls = $fmt->appulse();

This method returns an Astro::App::Satpass2::FormatValue object based on the invocant, with the data coming from the {appulse} key of the original object's data, augmented with the {station} and {time} of the original data.

bodies

my $array_ref = $fmt->bodies();

For reasons that seemed logical at the time, the Astro::App::Satpass2 position() method produces a hash containing the time, some other relevant data, and a {bodies} key which contains a reference to an array of all the relevant bodies.

This method extracts an array of more-normally-structured Astro::App::Satpass2::FormatValue objects which give access to the original bodies.

center

$center = $fmt->center();

This method returns an Astro::App::Satpass2::FormatValue object based on the invocant, with the data coming from the {center} key of the original object's data, augmented with the {station} and {time} of the original data.

clone

my $clone = $fmt->( %arg );

This method performs a shallow clone the invocant. That is to say, the clone is a separate object, but it shares all contained objects and references with the original object. If any arguments are passed, they are used to initialize the cloned object, instead of the corresponding data from the invocant.

earth

my $earth = $fmt->earth();

This method returns an Astro::App::Satpass2::FormatValue object based on the invocant, with its {station} key set to the center of the Earth.

events

foreach my $event ( @{ $fmt->events() || [] } ) {
    ... do something with the event ...
}

This method returns a reference to an array of Astro::App::Satpass2::FormatValue objects manufactured out of the contents of the {events} key of the invocant's data.

reflections

$array_ref = $fmt->reflections();

This method returns a reference to an array of Astro::App::Satpass2::FormatValue objects which represent the results of calling $fmt->body()->reflection(), passing it the contents of the {station} and {time} keys. It will return undef if the body does not support this method, or if it is below the horizon or not lit.

station

my $station = $fmt->station();

This method returns an object identical to the invocant, with the exception that the {body} and {station} contents are exchanged. With this,

$fmt->station()->latitude()

(e.g.) gets you the latitude of the observing station, whereas

$fmt->latitude()

would get you the latitude of the orbiting body.

Formatters

Each formatter converts the value of a specific key or keys in the data hash to text. Typically the conversion is to a fixed-width field unless the width argument is non-numeric. If the underlying item does not exist, a user-specified string will be returned instead, or spaces if no string was specified.

All the formatter arguments are passed by name: that is, as name/value pairs. Because of the idiosyncrasies of Template-Toolkit, or because of the author's lack of experience with it, some weirdness has been introduced into what would have been a straightforward signature:

* Template-Toolkit recognizes special named-argument syntax, and presents the arguments as a hash appended to the argument list. Therefore, if the formatters see a hash as the last argument, that hash will be expanded into a list and prepended to the argument list. Because Template-Toolkit does not supply an empty hash if none of its named arguments are seen, you can not pass a hash as the last argument.

* Template-Toolkit seems to have a strong preference for dealing with arrays as references. But array references are not flattened when passed as arguments. If the caller wants an array reference flattened, it must be made into an instance of Astro::App::Satpass2::Wrap::Array. This is really (I think and hope!) only a problem for whoever writes the code reference that gets passed to the local_coordinates argument of new() (i.e. me).

The summary of all this is that arguments are taken in the following order:

1) arguments from the final hash, if any
2) everything else except
3) Astro::App::Satpass2::Wrap::Array objects, which are expanded and put last.

Since arguments are passed by name, you can specify the same argument more than once. If this happens, the last specification of the argument is the one taken.

One additional complication: for convenience in overriding default titles, if the list of arguments from item (2) above ('everything else') has an odd number of elements, 'title' is prepended. The net result of this is that if $title is an Astro::App::Satpass2::FormatValue object with title => 1, something like $title->azimuth( '' ) will produce an empty field of the proper width.

The following arguments are accepted by all formatters:

align_left

This argument specifies that the given value be left-aligned in its field. This defaults to true for text items, and false for numeric items.

literal

This argument specifies text to be displayed in place of the underlying datum.

missing

This argument specifies the text to be filled in if the underlying datum is not available. It defaults to spaces.

title

This argument specifies the text to be used as the title of the formatter -- that is, the text which is displayed when the formatter is initialized with title => 1. The default is appropriate to the formatter.

almanac

print $fmt->almanac();

The almanac_hash() method provided by some subclasses of Astro::Coord::ECI returns a hash which includes an {almanac} key, which contains various items describing the almanac entry. This method provides access to the contents of the {almanac} key.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any almanac_pseudo_units units are accepted; anything else will result in an exception. The default is description.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 40.

altitude

print $fmt->altitude();

This method formats the altitude of the {body} object above sea level.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 7.

angle

print $fmt->angle();

This method formats the {angle} value, which typically represents an appulse angle.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 5.

apoapsis

print $fmt->apoapsis();

This method formats the apoapsis of the {body} object's orbit.

In addition to the standard arguments, it takes the following:

as_altitude

If this boolean argument is true (in the Perl sense) the value is given as altitude above the Earth's surface. If false, the value is given as distance from the Earth's center. The default is 1.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

apogee

print $fmt->apogee();

This method formats the apogee of the {body} object's orbit. Yes, this is the same as the apoapsis.

In addition to the standard arguments, it takes the following:

as_altitude

If this boolean argument is true (in the Perl sense) the value is given as altitude above the Earth's surface. If false, the value is given as distance from the Earth's center. The default is 1.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

argument_of_perigee

print $fmt->argument_of_perigee();

This method formats the argument of perigee from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 4.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 9.

ascending_node

print $fmt->ascending_node();

This method formats the ascending node from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 2.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is right_ascension.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 11.

azimuth

print $fmt->azimuth();

This method formats the azimuth of the {body} object as seen from the {station} object.

In addition to the standard arguments, it takes the following:

bearing

This argument specifies the size of the bearing information to append to the azimuth. If zero or any non-numeric value, no bearing information will be appended. The default is 0.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 5.

b_star_drag

print $fmt->b_star_drag();

This method formats the B* drag from the {body} object's TLE data..

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 4.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 11.

classification

print $fmt->classification();

This method formats the classification of the {body} object's TLE data. This will usually be 'U', for 'unclassified'.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 1.

date

print $fmt->date();

This method formats the {time} value using the date_format template. This is intended to produce the date, without time information.

In addition to the standard arguments, it takes the following:

delta

This argument specifies a number of seconds to add to the value before it is formatted. The default is 0.

format

This argument specifies the format to use for formatting the value. The default is ...

gmt

If this boolean argument is true, the value is formatted in GMT, regardless of how the time formatter is set up. If false, it is formatted according to the time_formatter's zone setting. The default is the time_formatter's gmt setting.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 5.

units

This argument specifies the units of the field. Any time_units units are accepted; anything else will result in an exception. The default is local.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is .

declination

print $fmt->declination();

This method formats the declination of the {body} object as seen from the {station} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 5.

eccentricity

print $fmt->eccentricity();

This method formats the eccentricity of the {body} object's orbit.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 5.

units

This argument specifies the units of the field. Any dimensionless units are accepted; anything else will result in an exception. The default is unity.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 8.

effective_date

print $fmt->effective_date();

This method formats the effective date of the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

format

This argument specifies the format to use for formatting the value. The default is ...

gmt

If this boolean argument is true, the value is formatted in GMT, regardless of how the time formatter is set up. If false, it is formatted according to the time_formatter's zone setting. The default is the time_formatter's gmt setting.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is .

units

This argument specifies the units of the field. Any time_units units are accepted; anything else will result in an exception. The default is local.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is .

element_number

print $fmt->element_number();

This method formats the number of the {body} object's TLE data. This is usually incremented each time a new set is published.

In addition to the standard arguments, it takes the following:

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 4.

elevation

print $fmt->elevation();

This method formats the elevation of the {body} object above the horizon as seen from the {station} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 5.

ephemeris_type

print $fmt->ephemeris_type();

This method formats the ephemeris type of the {body} object's TLE data. This is supposed to say which model is to be used to calculate the object's position, but in practice is typically 0 or blank.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 1.

epoch

print $fmt->epoch();

This method formats the epoch from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

format

This argument specifies the format to use for formatting the value. The default is ...

gmt

If this boolean argument is true, the value is formatted in GMT, regardless of how the time formatter is set up. If false, it is formatted according to the time_formatter's zone setting. The default is the time_formatter's gmt setting.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is .

units

This argument specifies the units of the field. Any time_units units are accepted; anything else will result in an exception. The default is local.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is .

event

print $fmt->event();

This method formats the contents of {event}, which generally comes from an Astro::Coord::ECI::TLE pass() calculation.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any event_pseudo_units units are accepted; anything else will result in an exception. The default is localized.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 5.

first_derivative

print $fmt->first_derivative();

This method formats the first derivative from the {body} object's TLE data. The units are actually angle per minute squared, but this formatter treats them as angle. That is, it will give you output in radians per minute squared if you so desire, but not in radians per second squared.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 10.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 17.

fraction_lit

print $fmt->fraction_lit();

This method formats the fraction of the {body} object which is lit. This is only available if that object supports the phase() method.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 2.

units

This argument specifies the units of the field. Any dimensionless units are accepted; anything else will result in an exception. The default is unity.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 4.

illumination

print $fmt->illumination();

This method formats the contents of {illumination}, which generally comes from an Astro::Coord::ECI::TLE pass() calculation, though it is also present if the template calls data.bodies().

If the satellite is above the horizon, the illumination returned by bodies() is the same as that provided by the pass calculation. Prior to version 0.019_01, nothing was returned if the satellite was below the horizon. Beginning with version 0.019_01, the satellite will be shown as either lit or shadowed if it is below the horizon.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any event_pseudo_units units are accepted; anything else will result in an exception. The default is localized.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 5.

inclination

print $fmt->inclination();

This method formats the orbital inclination from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 4.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 8.

inertial

print $fmt->inertial()

This method formats the inertial attribute of the {body} object, as 0 if the attribute is false, or 1 if it is true.

In addition to the standard arguments, it takes the following:

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 1.

international

print $fmt->international();

This method formats the international launch designator from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 8.

latitude

print $fmt->latitude();

This method formats the latitude of the {body} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 4.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 8.

list

print $fmt->list();

This method formats the object as specified by the list_formatter argument when the object was initialized. It has no arguments of its own, but will pass through any arguments given to the methods it calls. See local_coord() below for details.

local_coord

print $fmt->local_coord();

This method formats the local coordinates as specified by the local_coordinates argument when the object was initialized. It has no arguments of its own, but will pass through any arguments given to the methods it calls. You can pass arguments selectively by specifying them as a hash - for example $fmt->local_coord( title => { azimuth => 'azimuth', elevation => 'elevation', }, );

Scalar arguments will be passed to all called methods, except for append, which will be appended to the entire formatted value.

longitude

print $fmt->longitude();

This method formats the longitude of the {body} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 4.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 9.

magnitude

print $fmt->magnitude();

This method formats the contents of {data}{magnitude}, which generally represents the magnitude of an Iridium flare. If {magnitude} is undefined but the body supports the magnitude() method, the body time is set to the contents of {time}, and then $body->magnitude( $station ) is called.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 4.

maidenhead

print $fmt->maidenhead();

This method formats the Maidenhead Grid Locator position of the {body} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the precision of the position, as the number of grid levels to provide. The default is half the width, truncated to an integer. If no specific width is provided, the default is 3.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

mean_anomaly

print $fmt->mean_anomaly();

This method formats the mean anomaly from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 4.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 9.

mean_motion

print $fmt->mean_motion();

This method formats the mean motion from the {body} object's TLE data. The units are actually angle per minute, but this formatter treats them as angle. That is, it will give you output in radians per minute if you so desire, but not in radians per second.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 10.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 12.

mma

print $fmt->mma();

This method formats the contents of {mma}, which generally indicates the flaring antenna for an Iridium flare.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 3.

name

print $fmt->name();

This method formats the name of the {body} object. If the name is missing and you specify missing => 'oid' the OID will be displayed instead.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 24.

oid

print $fmt->oid();

This method formats the OID of the {body} object.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

operational

print $fmt->operational();

This method formats the operational status of the {body} object. This is generally only available if the object represents an Iridium satellite.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 1.

periapsis

print $fmt->periapsis();

This method formats the periapsis of the {body} object's orbit.

In addition to the standard arguments, it takes the following:

as_altitude

If this boolean argument is true (in the Perl sense) the value is given as altitude above the Earth's surface. If false, the value is given as distance from the Earth's center. The default is 1.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

perigee

print $fmt->perigee();

This method formats the perigee of the {body} object's orbit. Yes, this is the same as the periapsis.

In addition to the standard arguments, it takes the following:

as_altitude

If this boolean argument is true (in the Perl sense) the value is given as altitude above the Earth's surface. If false, the value is given as distance from the Earth's center. The default is 1.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

period

print $fmt->period();

This method formats the period of the {body} object's orbit.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any duration units are accepted; anything else will result in an exception. The default is composite.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 12.

phase

print $fmt->phase();

This method formats the phase of the {body} object. This is only available if that object supports the phase() method.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 4.

range

print $fmt->range();

This method formats the distance of the {body} object from the {station} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 1.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 10.

revolutions_at_epoch

print $fmt->revolutions_at_epoch();

This method formats the revolutions at epoch from the {body} object's TLE data.

In addition to the standard arguments, it takes the following:

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

right_ascension

print $fmt->right_ascension();

This method formats the right ascension of the {body} object as seen from the {station} object.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is right_ascension.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 8.

second_derivative

print $fmt->second_derivative();

This method formats the second derivative from the {body} object's TLE data. The units are actually angle per minute cubed, but this formatter treats them as angle. That is, it will give you output in radians per minute cubed if you so desire, but not in radians per second cubed.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 10.

units

This argument specifies the units of the field. Any angle_units units are accepted; anything else will result in an exception. The default is degrees.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 17.

semimajor

print $fmt->semimajor();

This method formats the semimajor axis of the {body} object's orbit, calculated using that object's semimajor() method.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

semiminor

print $fmt->semiminor();

This method formats the semiminor axis of the {body} object's orbit, calculated using that object's semiminor() method.

In addition to the standard arguments, it takes the following:

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 0.

units

This argument specifies the units of the field. Any length units are accepted; anything else will result in an exception. The default is kilometers.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 6.

status

print $fmt->status();

This method formats the contents of {status}, which usually come from the Astro::App::Satpass2 position() method.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 60.

time

print $fmt->time();

This method formats the {time} value using the time_format template. This is intended to produce the time, without date information.

In addition to the standard arguments, it takes the following:

delta

This argument specifies a number of seconds to add to the value before it is formatted. The default is 0.

format

This argument specifies the format to use for formatting the value. The default is ...

gmt

If this boolean argument is true, the value is formatted in GMT, regardless of how the time formatter is set up. If false, it is formatted according to the time_formatter's zone setting. The default is the time_formatter's gmt setting.

places

This argument specifies the number of decimal places in the field. Specify a non-numeric value if you do not wish to enforce a specific number of decimal places. The default is 5.

units

This argument specifies the units of the field. Any time_units units are accepted; anything else will result in an exception. The default is local.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is .

tle

print $fmt->tle();

This method formats the TLE data from the {body} object. Unlike the other formatters, which produce a fixed-width string, this formatter produces a block of text, whatever is contained by the {body} object's tle attribute if any.

type

print $fmt->type();

This method formats the contents of {type}. This usually comes from the flare() method, and says whether the flare occurred in the am, day, or pm.

In addition to the standard arguments, it takes the following:

units

This argument specifies the units of the field. Any string_pseudo_units units are accepted; anything else will result in an exception. The default is string.

width

This argument specifies the width of the field. Specify a non-numeric value if you do not wish to enforce a specific width. The default is 3.

Title Control

Titles can consist of multiple lines, wrapped with Text::Wrap. The display is 'top-heavy', meaning that the column titles are justified to the top.

Nothing special needs to be done to get the first line, other than to initialize the object title => 1. To get all the lines, you need to use a while loop, calling more_title_lines() in the test. When this returns false you must exit the loop, otherwise you loop infinitely.

is_valid_title_gravity

Returns a true value if the argument is a valid title gravity setting, and a false value otherwise. Can be called as a static method, or even a subroutine, though it is not exported.

more_title_lines

my $fmt = Astro::App::Satpass2::Format->new( title => 1 );
while ( $fmt->more_title_lines() ) {
    print join( ' ',
        $fmt->azimuth( title => 'Azimuth of object',
            bearing => 2 ),
        $fmt->elevation( title => 'Elevation of object' ),
    ), "\n";
}

This method returns true until there are no more lines of title to display. It also increments the internal line counter causing the next line of title to be displayed.

reset_title_lines

my $fmt->reset_title_lines();

This method resets the title line logic to its original state. You will not normally need to call this unless you want to display titles more than once and you have previously exited a more_title_lines() loop prematurely.

Adding format effectors

add_formatter_method

$fmt->add_formatter_method( ... );

This experimental method takes as its arguments one or more Astro::App::Satpass2::FormatValue::Formatter objects, and makes them available for use in formatting values. An exception will be thrown if you try to replace an existing formatter, whether it is built-in or previously added with this method.

It is not anticipated that the user will need to call this directly. Instead the formatter object will call it on the user's behalf.

The whole idea of custom format effectors is highly experimental, and should be considered undocumented and subject to change without notice.

UNITS

Most of the format effectors format a quantity that is measured in some physical units; that is, kilometers, feet, seconds, or whatever. The units= argument can be used to specify the displayed units for the field. This mechanism has been subverted in a couple cases to select among the representations of items that have more than one representation, even when the different representations are not, strictly speaking, physical units.

Each format effector that has physical units has an associated dimension, which determines which units are valid for it. The dimension specifies units, synonyms for canonical units, and the default units, though the individual format effector can have its own default (e.g. right_ascension).

Typically the default field widths and decimal places are appropriate for the default units, so if you specify different units you should probably specify the field width and decimal places as well.

The dimensions are:

almanac_pseudo_units

The first example is a case where the units mechanism was subverted to select among alternate representations, rather than to convert between physical units. The possible pseudo-units are:

description = the text description of the event;

event = the generic name of the event (e.g. 'horizon' for rise or set);

detail = the numeric event detail, whose meaning depends on the event (e.g. for 'horizon', 1 is rise and 0 is set).

The default is 'description'.

angle_units

This dimension represents a geometric angle. The possible units are:

bearing = a compass bearing;

decimal = a synonym for degrees;

degrees = angle in decimal degrees;

radians = angle in radians;

phase = name of phase ('new', 'waxing crescent', and so on);

right_ascension = angle in hours, minutes, and seconds of right ascension.

When the angle units are specified as units => 'bearing', the precision of the bearing is specified by the bearing argument. That is, bearing => 1 gets you the cardinal points (N, E, S and W), bearing => 2 gets you the semi-cardinal points, and similarly for bearing => 3. If bearing is not specified it defaults to the same value as the width argument, or 2 if no width is specified. The net result is that you need to specify the bearing argument if you specify width => '' and do not like the default of 2. Yes, I could have equivocated on places, but this seemed more straight forward.

The default is normally degrees, though this is overridden for right_ascension.

dimensionless

A few displayed quantities are simply numbers, having no associated physical dimension. These can be specified as:

percent = display as a percentage value, without the trailing '%';

unity = display unaltered.

The default is unity.

duration

This dimension represents a span of time, such as an orbital period. The units are:

composite = days hours:minutes:seconds.fraction;

days = duration in days and fractions of days;

hours = duration in hours and fractions of hours;

minutes = duration in minutes and fractions of minutes;

seconds = duration in seconds and fractions of seconds.

The default is composite.

event_pseudo_units

Like almanac_pseudo_units, this is not a physical dimension, just a way of selecting different representations. The units are:

integer = event number (see Astro::Coord::ECI::TLE);

localized = localized event name;

string = unlocalized event name.

The default is localized.

length

This dimension represents lengths and distances. The possible units are:

feet = US/British feet;

ft = synonym for 'feet';

kilometers = standard kilometers;

km = synonym for kilometers;

meters = standard meters;

m = synonym for 'meters';

miles = statute miles.

The default is kilometers.

string_pseudo_units

Like almanac_pseudo_units, this is not a physical dimension, just a way of selecting different representations. The units are:

lower_case = all lower case;

string = the unmodified string;

title_case = lower case, with initial letters upper case,

upper_case = all upper case.

time_units

This dimension represents time. The possible units are:

days_since_epoch = the number of days and fractions thereof since the epoch of the body (undefined if there is no epoch);

gmt = GMT;

julian = Julian day (implies GMT -- you may want to set the places argument for this);

local = local time (actually, whatever zone the time formatter is set to);

universal = an alias for gmt;

z = an alias for gmt;

zulu = an alias for gmt.

The default is local.

SUPPORT

Support is by the author. Please file bug reports at http://rt.cpan.org, or in electronic mail to the author.

AUTHOR

Thomas R. Wyant, III wyant at cpan dot org

COPYRIGHT AND LICENSE

Copyright (C) 2010-2019 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.