All Downloads are FREE. Search and download functionalities are using the official Maven repository.

decodes.xml.EngineeringUnitParser Maven / Gradle / Ivy

Go to download

A collection of software for aggregatting and processing environmental data such as from NOAA GOES satellites.

The newest version!
/*
*  $Id$
*
*  $State$
*
*  $Log$
*  Revision 1.1.1.1  2014/05/19 15:28:59  mmaloney
*  OPENDCS 6.0 Initial Checkin
*
*  Revision 1.1  2008/04/04 18:21:08  cvs
*  Added legacy code to repository
*
*  Revision 1.4  2004/08/30 14:49:30  mjmaloney
*  Added javadocs
*
*  Revision 1.3  2003/11/15 20:08:24  mjmaloney
*  Updates for new structures in DECODES Database Version 6.
*  Parsers now ignore unrecognized elements with a warning. They used to
*  abort. The new behavior allows easier future enhancements.
*
*  Revision 1.2  2001/06/30 13:37:22  mike
*  dev
*
*  Revision 1.1  2001/01/13 17:22:48  mike
*  Added parsers for EngineeringUnits
*
*/
package decodes.xml;

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import java.util.Enumeration;
import decodes.db.*;
import ilex.util.TextUtil;
import ilex.util.IDateFormat;
import ilex.util.Logger;
import java.io.IOException;
import ilex.xml.*;

/**
 * This class maps the DECODES XML representation for EngineeringUnit elements.
 */
public class EngineeringUnitParser 
	implements XmlObjectParser, XmlObjectWriter, TaggedStringOwner
{
	private EngineeringUnit eu; // object that we will build.

	private static final int nameTag = 0;
	private static final int familyTag = 1;
	private static final int measuresTag = 2;

	// Used by dbimport to detect if any new units were parsed.
	public static boolean engineeringUnitsParsed = false;
	
	/**
	 * @param ob the object in which to store the data.
	 */
	public EngineeringUnitParser( EngineeringUnit ob )
	{
		super();
		eu = ob;
	}

	/**
	 * @return name of element parsed by this parser
	 */
	public String myName( ) { return XmlDbTags.EngineeringUnit_el; }
		
	/**
	 * @param ch Characters from file
	 * @param start start of characters
	 * @param length length of characters
	 */
	public void characters( char[] ch, int start, int length ) throws SAXException
	{
		if (!TextUtil.isAllWhitespace(new String(ch, start, length)))
			throw new SAXException(
				"No character data expected within EngineeringUnit");
	}

	/**
	 * Called after start of new element for this parser is detected.
	 * @param hier the stack of parsers
	 * @param namespaceURI namespaceURI
	 * @param localName name of element
	 * @param qname ignored
	 * @param atts attributes for this element
	 * @throws SAXException on parse error
	 */
	public void startElement( XmlHierarchyParser hier, String namespaceURI, String localName, String qname, Attributes atts ) throws SAXException
	{
		engineeringUnitsParsed = true;
		if (localName.equalsIgnoreCase(XmlDbTags.name_el))
		{
			hier.pushObjectParser(new TaggedStringSetter(this, nameTag));
		}
		else if (localName.equalsIgnoreCase(XmlDbTags.Family_el))
		{
			hier.pushObjectParser(new TaggedStringSetter(this, familyTag));
		}
		else if (localName.equalsIgnoreCase(XmlDbTags.Measures_el))
		{
			hier.pushObjectParser(new TaggedStringSetter(this, measuresTag));
		}
		else
		{
			Logger.instance().log(Logger.E_WARNING,
				"Invalid element '" + localName + "' under " + myName()
				+ " -- skipped.");
			hier.pushObjectParser(new ElementIgnorer());
		}
	}

	/**
	 * Signals the end of the current element.
	 * Causes parser to pop the stack in the hierarchy. 
	 * @param hier the stack of parsers
	 * @param namespaceURI ignored
	 * @param localName element that is ending
	 * @param qname ignored
	 */
	public void endElement( XmlHierarchyParser hier, String namespaceURI, String localName, String qname ) throws SAXException
	{
		if (!localName.equalsIgnoreCase(myName()))
			throw new SAXException(
				"Parse stack corrupted: got end tag for " + localName
				+ ", expected " + myName());
		hier.popObjectParser();
	}

	/**
	 * Allows an object to keep track of whitespace, if needed.
	 * @param ch the whitespace
	 * @param start the start of the whitespace
	 * @param length the length of the whitespace
	 */
	public void ignorableWhitespace( char[] ch, int start, int length ) throws SAXException
	{
	}

	/**
	 * From TaggedStringOwner, called from TaggedStringSetter when string
	 * elements are parsed.
	 * @param tag the tag defined above
	 * @param str the string content of the element
	 * @throws SAXException if context or parse error
	 */
	public void set( int tag, String str ) throws SAXException
	{
		switch(tag)
		{
		case nameTag:
			eu.setName(str);
			break;
		case familyTag:
			eu.family = str;
			break;
		case measuresTag:
			eu.measures = str;
			break;
		}
	}

	/**
	 * Writes this object's data, along with subordinates, to an XML file.
	 * @param xos the output stream object
	 * @throws IOException on IO error
	 */
	public void writeXml( XmlOutputStream xos ) throws IOException
	{
		xos.startElement(myName(), XmlDbTags.EngineeringUnit_abbr_at, eu.abbr);

		if (eu.getName() != null)
			xos.writeElement(XmlDbTags.name_el, eu.getName());
		if (eu.family != null)
			xos.writeElement(XmlDbTags.Family_el, eu.family);
		if (eu.measures != null)
			xos.writeElement(XmlDbTags.Measures_el, eu.measures);

		xos.endElement(myName());
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy