package com.tom_roush.pdfbox.pdmodel.fdf;
import java.io.IOException;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.FactoryConfigurationError;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;
import org.xml.sax.SAXException;
/**
* This class with handle some simple XML operations.
*
* @author Ben Litchfield
*/
final class XMLUtil
{
/**
* Utility class, should not be instantiated.
*
*/
private XMLUtil()
{
}
/**
* This will parse an XML stream and create a DOM document.
*
* @param is The stream to get the XML from.
* @return The DOM document.
* @throws IOException It there is an error creating the dom.
*/
public static Document parse( InputStream is ) throws IOException
{
try
{
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = builderFactory.newDocumentBuilder();
return builder.parse( is );
}
catch (FactoryConfigurationError e )
{
throw new IOException( e.getMessage(), e );
}
catch (ParserConfigurationException e)
{
throw new IOException( e.getMessage(), e );
}
catch (SAXException e)
{
throw new IOException( e.getMessage(), e );
}
}
/**
* This will get the text value of an element.
*
* @param node The node to get the text value for.
* @return The text of the node.
*/
public static String getNodeValue( Element node )
{
StringBuilder sb = new StringBuilder();
NodeList children = node.getChildNodes();
int numNodes = children.getLength();
for( int i=0; i<numNodes; i++ )
{
Node next = children.item( i );
if( next instanceof Text )
{
sb.append(next.getNodeValue());
}
}
return sb.toString();
}
}