Applications of XML Oz OceanAtlas Software and NOAA/PMEL
How I Use XML Settings files for JOA resources including preferences, color palettes, color bars, interpolation surfaces, map settings. As a replacement EPIC pointer files for describing collections of metadata for profile and time-series data. EPIC pointer files are difficult to parse with a rigid format that is difficult to expand.
Advantages of XML Not an opaque binary object (e.g., a serialized Java object)-- viewable and editable using very simple tools Settings files not rendered obsolete when your program needs change. If you serialized a Java object that held the specifications, for example, a map, changing the map specification object would render all your existing settings files unreadable. Using XML you would simple add/remove tags. Your code simply ignores obsolete tags until overwritten by a new version. Easy to organize information into hierarchies and a kind of object inheritance.
Advantages of XML (continued) Easy to parse with readily available libraries--I use an ancient SAX parser. Probably easier to parse with more modern libraries.
Examples: Setting File yyyy-MMM-dd true 0
Examples: Setting File TEMP global 32 contours covering World Ocean ranges … …
Designing XML Files I have usually designed my XML files by building a DTD (Document Type Definition) file (unless it’s very simple). DTDs describe “rules for how the XML document elements, attributes, and other data are defined and logically related in an XML-compliant document.” Can also use the DTD to validate the correctness of an XML document. An XML document may also have an associated stylesheet that specifies how the document looks when displayed (e.g., in a web browser). I don’t build stylesheets because I’m not concerned with how they look.
Example of a DTD: EPIC XML Pointer File <!ATTLIST epicxml version CDATA #REQUIRED type (profile | time-series | grid | other) #REQUIRED URI CDATA #IMPLIED lexicon CDATA #IMPLIED> <!ATTLIST time location (start | end | point) #REQUIRED “point” units CDATA #IMPLIED > <!ATTLIST date location (start | end | point) #REQUIRED “point” year CDATA #REQUIRED month CDATA #REQUIRED day CDATA #REQUIRED hour CDATA #IMPLIED min CDATA #IMPLIED secs CDATA #IMPLIED> <!ATTLIST latitude location (north | south | start | end | point) #REQUIRED “point” units (degrees_north | degrees_south) #IMPLIED “degrees_north”> <!ATTLIST longitude location (east | west | start | end | point) #REQUIRED “point” units (degrees_east | degrees_west) #IMPLIED “degrees_east”> <!ATTLIST vertical location (top | bottom | start | end | point) #REQUIRED “point” units CDATA #REQUIRED positive CDATA "down"> <!ATTLIST variable name ID #REQUIRED units CDATA #REQUIRED description CDATA #IMPLIED lexicon CDATA #IMPLIED> <!ATTLIST fileset id CDATA #REQUIRED URI CDATA #IMPLIED> <!-- time should have location=”start”, “end” for time series, “point” for profile, vertical should have location=”top”, “bottom” for profile, “point” for time series, latitude and longitude should have location=”point” --> <!ATTLIST station id CDATA #REQUIRED cast CDATA #IMPLIED URI CDATA #IMPLIED bottom CDATA #IMPLIED reference CDATA #REQUIRED> <!ATTLIST grid id CDATA #REQUIRED URI CDATA #IMPLIED reference CDATA #REQUIRED> <!ATTLIST track id CDATA #REQUIRED URI CDATA #IMPLIED reference CDATA #REQUIRED> <!ATTLIST stationvalue cast CDATA #REQUIRED name CDATA #REQUIRED units CDATA #REQUIRED method CDATA #IMPLIED lexicon CDATA #IMPLIED value CDATA #REQUIRED> <!ATTLIST attribute name CDATA #REQUIRED value CDATA #REQUIRED>
Example EPIC XML Pointer File from DTD A dummy comment for testing XML Writing