public class DDS extends DStructure
Dataset {
Float64 lat[lat = 180];
Float64 lon[lon = 360];
Float64 time[time = 404];
Grid {
ARRAY:
Int32 sst[time = 404][lat = 180][lon = 360];
MAPS:
Float64 time[time = 404];
Float64 lat[lat = 180];
Float64 lon[lon = 360];
} sst;
} weekly;
If the data request to this dataset includes a constraint
expression, the corresponding DDS might be different. For
example, if the request was only for northern hemisphere data
at a specific time, the above DDS might be modified to appear like
this:
Dataset {
Grid {
ARRAY:
Int32 sst[time = 1][lat = 90][lon = 360];
MAPS:
Float64 time[time = 1];
Float64 lat[lat = 90];
Float64 lon[lon = 360];
} sst;
} weekly;
Since the constraint has narrowed the area of interest, the range
of latitude values has been halved, and there is only one time
value in the returned array. Note that the simple arrays (lat,
lon, and time) described in the dataset are also part of
the sst Grid object. They can be requested by themselves or as
part of that larger object.
BaseType variables now each have their own set of Attributes
it has become necessary to have a representation of the DDS that captures these
relationships. Consider the previous example. A correctly constructed
DAS for that DDS might look like:
Attributes {
lat {
String fullName "latitude";
String units "degrees North";
}
lon {
String fullName "longitude";
String units "degrees East";
}
time {
String units "seconds";
}
sst {
String fullName "Sea Surface Temperature";
String units "degrees centigrade";
sst {
Alias fullName .sst.fullName;
Alias units .sst.units;
}
time {
Alias units .time.units;
}
lat {
Alias fullName .lat.fullName;
Alias units .lat.units;
}
lon {
Alias fullName .lon.fullName;
Alias units .lon.units;
}
}
}
Combined with the DDS and expressed as a DDX it would look like:
The DDX can also be sent from a server to a client.<?xml version="1.0" encoding="UTF-8"?> <Dataset name="weekly" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xml.opendap.org/ns/DAP2" xsi:schemaLocation="http://xml.opendap.org/ns/DAP2 http://xml.opendap.org/dap/dap2.xsd" > <Array name="lat"> <Attribute name="fullName" type="String"> <value>"latitude"</value> </Attribute> <Attribute name="units" type="String"> <value>"degrees North"</value> </Attribute> <Float64/> <dimension name="lat" size="180"/> </Array> <Array name="lon"> <Attribute name="fullName" type="String"> <value>"longitude"</value> </Attribute> <Attribute name="units" type="String"> <value>"degrees East"</value> </Attribute> <Float64/> <dimension name="lon" size="360"/> </Array> <Array name="time"> <Attribute name="units" type="String"> <value>"seconds"</value> </Attribute> <Float64/> <dimension name="time" size="404"/> </Array> <Grid name="sst"> <Attribute name="fullName" type="String"> <value>"Sea Surface Temperature"</value> </Attribute> <Attribute name="units" type="String"> <value>"degrees centigrade"</value> </Attribute> <Array name="sst"> <Alias name="fullName" Attribute=".sst.fullName"/> <Alias name="units" Attribute=".sst.units"/> <Int32/> <dimension name="time" size="404"/> <dimension name="lat" size="180"/> <dimension name="lon" size="360"/> </Array> <Map name="time"> <Alias name="units" Attribute=".time.units"/> <Float64/> <dimension name="time" size="404"/> </Map> <Map name="lat"> <Alias name="fullName" Attribute=".lat.fullName"/> <Alias name="units" Attribute=".lat.units"/> <Float64/> <dimension name="lat" size="180"/> </Map> <Map name="lon"> <Alias name="fullName" Attribute=".lon.fullName"/> <Alias name="units" Attribute=".lon.units"/> <Float64/> <dimension name="lon" size="360"/> </Map> </Grid> <dataBLOB href="cid:ContentIdOfTheMIMEAttcahmentContainingTheDataBlob"/> </Dataset>
DDSParser to
build DDS's but to build them
using the DDS API. This is typical of devlopers
writing servers that work with
information rich data formats such as NetCDF or HDF. With the
addition of Attributes
(and Attribute containers) to all of the datatypes in the DAP
it is now possible to construct a DDS
that contains all of the source meta-data from the original data source. This is
an extremly useful thing. However, when building a DDS
using the DDS API be sure
to call the functions DDS.checkForAttributeNameConflict() and
DDS.resolveAliases() on the new DDS prior to releasing it from
the code that builds it. Otherwise the DDS may have functional problems!
See The OPeNDAP User Guide, or the documentation of the
BaseType class for descriptions of the OPeNDAP data types.DAPNode.CloneMapvars_nameClear, _nameEncoded, log| Constructor and Description |
|---|
DDS()
Creates an empty
DDS. |
DDS(BaseTypeFactory factory)
Creates an empty
DDS with the given
BaseTypeFactory. |
DDS(java.lang.String clearname)
Creates an empty
DDS with the given dataset name. |
DDS(java.lang.String clearname,
BaseTypeFactory factory)
Creates an empty
DDS with the given dataset name and
BaseTypeFactory. |
DDS(java.lang.String clearname,
BaseTypeFactory factory,
java.lang.String schema)
Creates an empty
DDS with the given dataset name and
BaseTypeFactory. |
| Modifier and Type | Method and Description |
|---|---|
void |
addVariable(BaseType v,
int part)
Adds a variable to the container.
|
void |
checkForAttributeNameConflict()
Check for name conflicts.
|
void |
checkSemantics(boolean all)
Check the semantics of the
DDS. |
DAPNode |
cloneDAG(DAPNode.CloneMap map)
Returns a clone of this
DDS. |
void |
delVariable(java.lang.String name)
Removes a variable from the
DDS. |
java.lang.String |
getBlobContentID()
Get's the dataBLOB Contnet-ID for this DDS.
|
DAS |
getDAS()
Creates a DAS object from the collection of
BaseType variables and their
associated Attributes. |
java.lang.String |
getDDSText()
This a wrapper method for
DDS.print(). |
java.lang.String |
getDDXText()
This a wrapper method for
DDS.printXML(). |
BaseTypeFactory |
getFactory()
Get the Class factory.
|
BaseType |
getVariable(java.lang.String name)
Returns a reference to the named variable.
|
java.util.Enumeration |
getVariables()
Returns an
Enumeration of the dataset variables. |
void |
ingestDAS(DAS das)
Takes the passed parameter
das and attempts
to incorporate it's contents into the Attributes of the DDS
variables. |
static java.lang.String |
normalize(java.lang.String field)
The
normalize method is used to normalize variable and
attribute name strings prior
to their comparison with the normalized tokens extracted from the
variable and name fields in an Alias declaration. |
int |
numVariables()
Returns the number of variables in the dataset.
|
boolean |
parse(java.io.InputStream stream) |
boolean |
parse(java.lang.String text) |
void |
parseXML(org.jdom2.Document ddxDoc,
boolean validation)
Reads a DDX from the named
Document. |
void |
parseXML(java.io.InputStream is,
boolean validation)
Reads a DDX from the named
InputStream. |
void |
print(java.io.OutputStream os)
Print the
DDS on the given OutputStream. |
void |
print(java.io.PrintWriter os)
Print the
DDS on the given PrintWriter. |
void |
printDAS(java.io.OutputStream os)
Print a DAS constructed from this DDS and it's BaseType variables.
|
void |
printDAS(java.io.PrintWriter pw)
Print a DAS constructed from this DDS and it's BaseType variables.
|
void |
printXML(java.io.PrintWriter pw)
Prints the peristent representation of the
DDS as an XML document. |
void |
printXML(java.io.PrintWriter pw,
java.lang.String pad,
boolean constrained)
Prints the peristent representation of the
DDS as an XML document. |
void |
resolveAliases()
Before the DDS can be used all of the Aliases in the various
AttributeTables must be resolved.
|
java.util.Stack |
search(java.lang.String name,
java.util.Stack compStack)
Look for
name in the DDS. |
void |
setBlobContentID(java.lang.String contentID)
Set's the dataBLOB reference for this DDS.
|
void |
setFactory(BaseTypeFactory btf)
Get the Class factory.
|
void |
setURL(java.lang.String url) |
static java.util.Vector |
tokenizeAliasField(java.lang.String field)
The
tokenizeAliasFiled() method is used to tokenize
the variable and the attribute fields in the alias
declaration. |
deserialize, elementCount, externalize, getTypeName, getVar, getVarCount, getVariableSet, printDecl, printValaddVariable, someChildHasAttributesaddAttributeAlias, addAttributeContainer, appendAttribute, appendAttribute, appendAttributeContainer, checkSemantics, delAttribute, delAttribute, elementCount, getAttribute, getAttribute, getAttributeNames, getAttributeTable, getLongName, hasAttributes, newPrimitiveVector, printAttributes, printAttributes, printAttributes, printAttributes, printConstraint, printDecl, printDecl, printDecl, printDecl, printDecl, printDecl, printDecl, printVal, printVal, printVal, printXML, printXML, printXML, setClearNameclone, cloneDAG, getClearName, getEncodedName, getParent, isProject, setEncodedName, setParent, setProject, setProject, setProjectedpublic DDS()
DDS.public DDS(java.lang.String clearname)
DDS with the given dataset name.clearname - the dataset namepublic DDS(BaseTypeFactory factory)
DDS with the given
BaseTypeFactory. This will be used for OPeNDAP servers which
need to construct subclasses of the various BaseType objects
to hold additional server-side information.factory - the server BaseTypeFactory object.public DDS(java.lang.String clearname,
BaseTypeFactory factory)
DDS with the given dataset name and
BaseTypeFactory. This will be used for OPeNDAP servers which
need to construct subclasses of the various BaseType objects
to hold additional server-side information.clearname - the dataset namefactory - the server BaseTypeFactory object.public DDS(java.lang.String clearname,
BaseTypeFactory factory,
java.lang.String schema)
DDS with the given dataset name and
BaseTypeFactory. This will be used for OPeNDAP servers which
need to construct subclasses of the various BaseType objects
to hold additional server-side information.clearname - the dataset namefactory - the server BaseTypeFactory object.schema - the URL where the parser can find an instance of the
OPeNDAP namespace schema.public void setURL(java.lang.String url)
public boolean parse(java.io.InputStream stream)
throws ParseException,
DAP2Exception
ParseExceptionDAP2Exceptionpublic boolean parse(java.lang.String text)
throws ParseException,
DAP2Exception
ParseExceptionDAP2Exceptionpublic final BaseTypeFactory getFactory()
public final void setFactory(BaseTypeFactory btf)
public void setBlobContentID(java.lang.String contentID)
contentID - A String containing the Content-ID of the MIME part that contains
the binary encoded data represented by this DDS.public java.lang.String getBlobContentID()
String containing the URL of the servers BLOB response for
this DDS.public DAS getDAS() throws DASException
BaseType variables and their
associated Attributes. This DAS is correctly formed (vis-a-vis the DAP
specification) for this DDS.DAS object for this DDS.DASExceptionDAS,
BaseTypepublic void printDAS(java.io.OutputStream os)
os - The OutputStream to print to.public void printDAS(java.io.PrintWriter pw)
pw - The PrintWriter to print to.public void delVariable(java.lang.String name)
DDS.
Does nothing if the variable can't be found.
If there are multiple variables with the same name, only the first
will be removed. To detect this, call the checkSemantics
method to verify that each variable has a unique name.name - the name of the variable to remove.checkSemantics(boolean)public BaseType getVariable(java.lang.String name) throws NoSuchVariableException
getVariable in class DStructurename - the name of the variable to return.name.NoSuchVariableException - if the variable isn't found.public void addVariable(BaseType v, int part)
addVariable in class DStructurev - the variable to add.part - ignored for DSequence.public java.util.Stack search(java.lang.String name,
java.util.Stack compStack)
throws NoSuchVariableException
name in the DDS. Start the search using the
ctor variable (or array/list of ctors) found on the top of the Stack
compStack (for component stack). When the named variable
is found, return the stack compStack modified so that it now contains
each ctor-type variable that on the path to the named variable. If the
variable is not found after exhausting all possibilities, throw
NoSuchVariable.
Note: This method takes the stack as a parameter so that it can be used by a parser that is working through a list of identifiers that represents the path to a variable as well as a shorthand notation for the identifier that is the equivalent to the leaf node name alone. In the form case the caller helps build the stack by repeatedly calling
search, in the latter case this method
must build the stack itself. This method is over kill for the first
case.name - Search for the named variable.compStack - The component stack. This holds the BaseType variables
that match the each component of a specific variable's name. This
method starts its search using the element at the top of the stack and
adds to the stack. The order of BaseType variables on the stack is the
reverse of the tree-traverse order. That is, the top most element on
the stack is the BaseType for the named variable, under that
is the named variable's parent and so on.NoSuchVariableExceptionpublic final java.util.Enumeration getVariables()
Enumeration of the dataset variables.getVariables in class DStructureEnumeration of BaseType.public final int numVariables()
public void parseXML(java.io.InputStream is,
boolean validation)
throws DAP2Exception
InputStream. This
method calls a generated parser to interpret an XML representation of a
DDS (aka a DDX), and instantiate that
DDS in memory. This method does the following:
DDSXMLParser using the BaseTypeFactory
held in this (the DDS) class.DDSXMLParser to parse the DDX waiting
in the InputStream is.DDS.checkForAttributeNameConflict()DDS.resolveAliases()DDS
is populated with variables ( by a parser, or through the DDS API)
and prior to releasing it for use to any calling program.is - the InputStream containing the DDS to parse.validation - Is a boolean indicating whether or not the parser should
validate the XML document using the Schema (typically referenced in the
document itself). In general server side applications should always vaidate,
while clients shouldn't bother (since they are ostensibly receiving the
document from a server that has already done so.)DDSException - thrown on an error constructing the
DDS.DAP2ExceptionDDSXMLParser,
checkForAttributeNameConflict(),
resolveAliases()public void parseXML(org.jdom2.Document ddxDoc,
boolean validation)
throws DAP2Exception
Document. This
method calls a generated parser to interpret an XML representation of a
DDS (aka a DDX), and instantiate that
DDS in memory. This method does the following:
DDSXMLParser using the BaseTypeFactory
held in this (the DDS) class.DDSXMLParser to parse the DDX waiting
in the InputStream is.DDS.checkForAttributeNameConflict()DDS.resolveAliases()DDS
is populated with variables ( by a parser, or through the DDS API)
and prior to releasing it for use to any calling program.ddxDoc - A JDOM Document containing the DDS to parse.validation - Is a boolean indicating whether or not the parser should
validate the XML document using the Schema (typically referenced in the
document itself). In general server side applications should always vaidate,
while clients shouldn't bother (since they are ostensibly receiving the
document from a server that has already done so.)DDSException - thrown on an error constructing the
DDS.DAP2ExceptionDDSXMLParser,
checkForAttributeNameConflict(),
resolveAliases()public void checkSemantics(boolean all)
throws BadSemanticsException
DDS. If
all is true, check not only the semantics of the
DDS itself, but also recursively check all variables
in the dataset.checkSemantics in class DStructureall - this flag indicates whether to check the semantics of the
member variables, too.BadSemanticsException - if semantics are badBaseType.checkSemantics(boolean)public void print(java.io.PrintWriter os)
DDS on the given PrintWriter.os - the PrintWriter to use for output.public final void print(java.io.OutputStream os)
DDS on the given OutputStream.os - the OutputStream to use for output.print(PrintWriter)public void resolveAliases()
throws MalformedAliasException,
UnresolvedAliasException,
NoSuchAttributeException
BaseType parameter
bt for Alias members of AttributeTables, and when they are found attempts to
resolve them to a specific Attribute.
This method should be called ONLY after the entire
DDS has been parsed and /or built using the DDS API.
currentBT.
This method manipulates the global (private) variable currentAT.public static java.lang.String normalize(java.lang.String field)
normalize method is used to normalize variable and
attribute name strings prior
to their comparison with the normalized tokens extracted from the
variable and name fields in an Alias declaration.
The rule for this normalization is as follows:
field - The string to be normalized.public static java.util.Vector tokenizeAliasField(java.lang.String field)
throws MalformedAliasException
tokenizeAliasFiled() method is used to tokenize
the variable and the attribute fields in the alias
declaration. It is required that these fields be normalized
in the XML instance document. The rules for this normalization
are as follows:
field - The string to be tokenized.MalformedAliasExceptionpublic void printXML(java.io.PrintWriter pw)
DDS as an XML document.
This XML document is know as a DDX. The DDX can be parsed using the
DDSXMLParserpublic void printXML(java.io.PrintWriter pw,
java.lang.String pad,
boolean constrained)
DDS as an XML document.
This XML document is know as a DDX. The DDX can be parsed using the
DDSXMLParserprintXML in class DConstructorpw - The PrintWriter to print to.pad - A String to print at the begining of each line.
typically this is some white space.constrained - A boolean that indcates if the this call should
print the constrained version of the DDS. A value of true will cause the
only the projected variables of the DDX to be printed .public void ingestDAS(DAS das)
das and attempts
to incorporate it's contents into the Attributes of the DDS
variables. If an Attribute in the DAS
can't be associated with a variable in a logical manner then
it is placed at the top level of the DDS. (Basically it becomes
a toplevel attribute in the dataset)das - The DAS to ingest.public void checkForAttributeNameConflict()
throws BadSemanticsException
BadSemanticsExceptionpublic java.lang.String getDDSText()
DDS.print().DDS.print() as
Stringprint(PrintWriter)public java.lang.String getDDXText()
DDS.printXML().DDS.printXML() as
StringprintXML(PrintWriter)public DAPNode cloneDAG(DAPNode.CloneMap map) throws java.lang.CloneNotSupportedException
DDS.
See DAPNode.cloneDag()cloneDAG in class DStructuremap - track previously cloned nodesjava.lang.CloneNotSupportedException