--- projects/cms/source/util/uk/org/iscream/cms/util/XMLStringParser.java 2001/03/14 23:25:30 1.11 +++ projects/cms/source/util/uk/org/iscream/cms/util/XMLStringParser.java 2001/03/16 01:33:46 1.12 @@ -3,7 +3,8 @@ package uk.org.iscream.util; //---IMPORTS--- import java.io.*; -import java.util.ArrayList; +import java.util.LinkedList; +import java.util.Iterator; import org.xml.sax.*; import org.xml.sax.helpers.*; import javax.xml.parsers.*; @@ -12,7 +13,7 @@ import javax.xml.parsers.*; * XMLStringParser - Used to assist in creating XMLPacket objects. * * @author $Author: tdb $ - * @version $Id: XMLStringParser.java,v 1.11 2001/03/14 23:25:30 tdb Exp $ + * @version $Id: XMLStringParser.java,v 1.12 2001/03/16 01:33:46 tdb Exp $ */ public class XMLStringParser extends DefaultHandler { @@ -21,7 +22,7 @@ public class XMLStringParser extends DefaultHandler { /** * The current CVS revision of this class */ - public final String REVISION = "$Revision: 1.11 $"; + public final String REVISION = "$Revision: 1.12 $"; //---STATIC METHODS--- @@ -58,8 +59,7 @@ public class XMLStringParser extends DefaultHandler { * within the XMLPacket. */ public void startElement (String uri, String name, String qName, Attributes atts) { - _indentLevel++; - _tagList.add(name); + _tagList.addLast(name); if (atts != null) { for (int i = 0; i < atts.getLength (); i++) { _packet.addParam(getPath()+".attributes."+atts.getLocalName(i), atts.getValue(i)); @@ -73,8 +73,7 @@ public class XMLStringParser extends DefaultHandler { * level. */ public void endElement (String uri, String name, String qName) { - _tagList.remove(_tagList.size() - 1); - _indentLevel--; + _tagList.removeLast(); } /** @@ -115,10 +114,12 @@ public class XMLStringParser extends DefaultHandler { * in the XMLPacket. */ private String getPath () { - String path = (String) _tagList.get(0); + String path = ""; if (_tagList.size() > 0) { - for (int i = 1 ; i < _tagList.size() ; i++) { - path = path + "." + (String) _tagList.get(i); + Iterator i = _tagList.iterator(); + path = (String) i.next(); + while(i.hasNext()) { + path = path + "." + (String) i.next(); } } return path; @@ -134,16 +135,11 @@ public class XMLStringParser extends DefaultHandler { } //---ATTRIBUTES--- - - /** - * To keep track of our identation level - */ - private int _indentLevel = 0; /** - * An ArrayList of tags + * A LinkedList of tags */ - private ArrayList _tagList = new ArrayList(); + private LinkedList _tagList = new LinkedList(); /** * A reference to the XMLPacket we are making