--- projects/cms/source/util/uk/org/iscream/cms/util/XMLPacketMaker.java 2001/01/18 01:55:57 1.8 +++ projects/cms/source/util/uk/org/iscream/cms/util/XMLPacketMaker.java 2001/03/16 00:39:42 1.15 @@ -1,60 +1,61 @@ //---PACKAGE DECLARATION--- -package uk.ac.ukc.iscream.util; +package uk.org.iscream.util; //---IMPORTS--- import java.io.*; -import java.util.ArrayList; - import org.xml.sax.*; -import javax.xml.parsers.SAXParserFactory; -import javax.xml.parsers.ParserConfigurationException; -import javax.xml.parsers.SAXParser; +import javax.xml.parsers.*; /** * XMLPacketMaker - Creates an XMLPacket object. * * @author $Author: tdb $ - * @version $Id: XMLPacketMaker.java,v 1.8 2001/01/18 01:55:57 tdb Exp $ + * @version $Id: XMLPacketMaker.java,v 1.15 2001/03/16 00:39:42 tdb Exp $ */ -public class XMLPacketMaker extends HandlerBase { +public class XMLPacketMaker { //---FINAL ATTRIBUTES--- /** * The current CVS revision of this class */ - public final String REVISION = "$Revision: 1.8 $"; - + public final String REVISION = "$Revision: 1.15 $"; + + /** + * A reference to the system saxParser factory + */ + private final SAXParserFactory _factory = SAXParserFactory.newInstance(); + //---STATIC METHODS--- //---CONSTRUCTORS--- - // Constructor for accepting XML input. - public XMLPacketMaker (String xml) { - _xml = xml; - } - //---PUBLIC METHODS--- - public XMLPacket createXMLPacket() { + /** + * Method to create an XML packet from the data this + * class was constructed with. + * + * @param xml the XML String to parse + * @return an XMLPacket representing the XML String given + * @throws InvalidXMLException if the XML cannot be parsed + */ + public XMLPacket createXMLPacket(String xml) throws InvalidXMLException { // Create the XMLPacket to store values in. XMLPacket packet = new XMLPacket(); - - // Use the default (non-validating) parser - SAXParserFactory factory = SAXParserFactory.newInstance(); + try { - // Parse the input - InputSource inputSource = new InputSource(new StringReader(_xml)); - SAXParser saxParser = factory.newSAXParser(); - saxParser.parse(inputSource, new XMLStringParser(packet)); - + InputSource inputSource = new InputSource(new StringReader(xml)); + _factory.newSAXParser().parse(inputSource, new XMLStringParser(packet)); } catch (Exception e) { - return null; + // couldn't parse the XML for some reason + throw new InvalidXMLException("Could not parse the XML: "+xml); } + // parsed successfully, return the packet return packet; } @@ -62,7 +63,7 @@ public class XMLPacketMaker extends HandlerBase { * Overrides the {@link java.lang.Object#toString() Object.toString()} * method to provide clean logging (every class should have this). * - * This uses the uk.ac.ukc.iscream.util.NameFormat class + * This uses the uk.org.iscream.util.NameFormat class * to format the toString() * * @return the name of this class and its CVS revision @@ -79,11 +80,6 @@ public class XMLPacketMaker extends HandlerBase { //---ACCESSOR/MUTATOR METHODS--- //---ATTRIBUTES--- - - /** - * Holds the xml - */ - String _xml; /** * This is the friendly identifier of the