NAME
Astro::NED::Query - base class for NED queries
SYNOPSIS
use base qw/ Astro::NED::Query /;
DESCRIPTION
This class is the base class for queries to NED. As such, it is not used directly in end-user applications. Use the classes Astro::NED::Query::ByName, Astro::NED::Query::NearName, Astro::NED::Query::NearPosition instead.
However, since most of the functionality of those classes is derived from this one, most of the documentation for their use is found here. Documentation for the other classes will provide class specific details.
Usage
Constructing a query
Queries are constructed by creating a query object. The object should be created in one of the classes listed above. For brevity in the following documentation, it will shown as being in the Astro::NED::Query class. Don't use this in actual code!. You cannot construct a pure Astro::NED::Query object.
$query = Astro::NED::Query->new( Field1 => $value1,
Field2 => $value2, ... );
This constructs a query, setting the query parameters Field1 and Field2. It does not send off the query. Only single valued parameters may be set when constructing the query.
When an object is constructed, the appropriate search parameter form is retrieved from NED. To avoid repeatedly doing this, reuse a query object as much as possible.
Query Parameters and Accessor Methods
Query parameters come in two flavors: single valued and multiple valued. As shown above, single valued query parameters may be specified in the constructor.
Once a query has been constructed, parameters may be set or retrieved using accessor methods. These methods have the same name as the parameter. For single valued fields,
$query->Field1( $value );
$value = $query->Field1;
Accessor methods for fields which can have multiple concurrent values have a slightly different syntax:
$query->MField( $value => $state );
$state = $query->MField( $value );
Here, $state
is a boolean value which indicates whether or not the field should contain that value. Think of it as a check box toggle switch. The value returned by the accessor will be empty if the field contains that value, else it is the actual value.
All of the parameters may be set to their default state by calling the reset method. To make the default values look like the current values, use the set_default method.
Some parameters may have values which are restricted to a given set. To determine what the available values are, use the possible_values method.
Sending off the request
Once a query has been constructed, it is sent off to NED with the query method. This method will return an object (in the computer science sense) which contains the results of the query. The type of object returned depends upon the type of query. For instance, queries which fall under the NED "Objects" rubric all return an Astro::NED::Response::Objects object.
The query object may be reused as often as one would like; simply change the parameter values and reissue the query method.
Examples
- Querying by name
-
$req = Astro::NED::Query::ByName->new( ObjName => 'Abell 2166', Extend => 1 ); $res = $req->query; print $_->Name, "\n" foreach @{$res->objects};
- Querying near name for Galaxies with X-ray emission
-
$req = Astro::NED::Query::NearName->new( ObjName => 'Abell 2166'); $req->IncObjType( Galaxies => 1 ); $req->IncObjType( Xray => 1 ); $req->ObjTypeInclude( 'ALL' ); $res = $req->query; print $_->Name, "\n" foreach @{$res->objects};
Generic Methods
All of the various Query classes share the following methods. Make sure to read the documentation for the actual Query class which will be used. It contains class specific information.
- new
-
This is the object constructor. It takes a list of keyword and value pairs. The keywords may be the names of single valued query parameters, or may be class options. These are documented for each Query class.
- possible_values
-
@values = $req->possible_values( $field_name );
This returns a list of the possible values for a query parameter. This is only useful for parameters whose values are limited to a specific set of values. For other parameters, an empty list is returned.
- reset
-
$req->reset;
This method resets the parameter values to their defaults. The default values are initially taken from the NED defaults, but may be changed with the set_default method.
- set_default
-
$req->set_default;
This sets the current parameter values as the default values.
- query
-
$res = $req->query;
Send the query off to NED. It returns a container containing the results of the query. See the documentation for the separate Query classes for information on the type of container and how to extract data from it.
- form
-
@keyw = $req->form;
Returns the current parameters as a sequence of key/value pairs. Note that keys might be repeated which means that some values might be lost if the return values are assigned to a hash.
Constructing new Query Classes
EXPORT
None by default.
AUTHOR
Diab Jerius, <djerius@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (C) 2003 Smithsonian Astrophysical Observatory. All rights are of course reserved.
It is released under the GNU General Public License. You may find a copy at
http://www.fsf.org/copyleft/gpl.html
SEE ALSO
Astro::NED::Query::Objects, Astro::NED::Query::ByName, Astro::NED::Query::NearName, Astro::NED::Query::NearPosition, Astro::NED::Query::Response::Objects, Astro::NED::Query::Response::Object, perl.