// $Id: XmlSinglePanelHandler.java 15430 2008-07-31 22:25:51Z penyaskito $ // Copyright (c) 2008 The Regents of the University of California. All // Rights Reserved. Permission to use, copy, modify, and distribute this // software and its documentation without fee, and without a written // agreement is hereby granted, provided that the above copyright notice // and this paragraph appear in all copies. This software program and // documentation are copyrighted by The Regents of the University of // California. The software program and documentation are supplied "AS // IS", without any accompanying services from The Regents. The Regents // does not warrant that the operation of the program will be // uninterrupted or error-free. The end-user understands that the program // was developed for research purposes and is advised not to rely // exclusively on the program for any reason. IN NO EVENT SHALL THE // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, // UPDATES, ENHANCEMENTS, OR MODIFICATIONS. package org.argouml.core.propertypanels.xml; import java.util.Dictionary; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; /** * This handles the XML events by SAX Api for building * the property panels. * @author penyaskito */ public class XmlSinglePanelHandler extends DefaultHandler { /** * The panel that will host the controls. */ private final Dictionary<String, XMLPropertyPanelsData> data; /** * the panel that we are traversing */ private XMLPropertyPanelsData currentPanel = null; private XMLPropertyPanelsDataRecord current = null; /** * Default constructor. * @param theData The XMLPropertyPanelsData that will * host the info read. */ public XmlSinglePanelHandler( Dictionary<String, XMLPropertyPanelsData> theData) { this.data = theData; } public void startElement(String namespaceURI, String localName, String qName, Attributes attr) throws SAXException { // ignore the parent node, is only the container if ("panels".equals(localName)) { return; } if ("panel".equals(localName)) { if (this.currentPanel == null) { currentPanel = new XMLPropertyPanelsData(); currentPanel.addPanel( new XMLPropertyPanelsDataRecord(localName, attr.getValue("name"))); } } else { XMLPropertyPanelsDataRecord record = new XMLPropertyPanelsDataRecord(localName, attr.getValue("name")); if (isChild(localName)) { current.addChild(record); } else if (hasChildren(localName)) { current = record; currentPanel.addProperty(record); } else { currentPanel.addProperty(record); } } } @Override public void endElement(String namespaceURI, String localName, String qName) throws SAXException { if ("panel".equals(localName)) { data.put(currentPanel.getTitle(), currentPanel); currentPanel = null; } } private boolean isChild(String elementName) { // for now, the only child are checkboxes. return "checkbox".equals(elementName); } private boolean hasChildren(String elementName) { // for now, the only element that can have // children are checkgroups. return "checkgroup".equals(elementName); } }