/* * NOTE: This copyright does *not* cover user programs that use HQ * program services by normal system calls through the application * program interfaces provided as part of the Hyperic Plug-in Development * Kit or the Hyperic Client Development Kit - this is merely considered * normal use of the program, and does *not* fall under the heading of * "derived work". * * Copyright (C) [2004, 2005, 2006], Hyperic, Inc. * This file is part of HQ. * * HQ is free software; you can redistribute it and/or modify * it under the terms version 2 of the GNU General Public License as * published by the Free Software Foundation. This program is distributed * in the hope that it will be useful, but WITHOUT ANY WARRANTY; without * even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA. */ package org.hyperic.hq.bizapp.shared.resourceImport; import org.hyperic.util.xmlparser.XmlAttr; import org.hyperic.util.xmlparser.XmlAttrHandler; import org.hyperic.util.xmlparser.XmlTagEntryHandler; import org.hyperic.util.xmlparser.XmlTagExitHandler; import org.hyperic.util.xmlparser.XmlTagHandler; import org.hyperic.util.xmlparser.XmlTagInfo; import java.util.List; class ApplicationTag implements XmlAttrHandler, XmlTagHandler, XmlTagEntryHandler, XmlTagExitHandler { private XmlAttr[] attrs; private XmlApplicationValue appValue; // Current working app private List applicationList; // List to fill out ApplicationTag(List applicationList){ String[] required, optional; required = XmlApplicationValue.getRequiredAttributes(); optional = XmlApplicationValue.getOptionalAttributes(); this.attrs = Parser.convertGhettoToAttrs(required, optional); this.applicationList = applicationList; } public String getName(){ return "application"; } public XmlAttr[] getAttributes(){ return this.attrs; } public XmlTagInfo[] getSubTags(){ return new XmlTagInfo[] { new XmlTagInfo(new ApplicationServiceListTag(this.appValue), XmlTagInfo.REQUIRED), }; } public void handleAttribute(int idx, String value){ try { this.appValue.setValue(this.attrs[idx].getName(), value); } catch(XmlInvalidAttrException exc){ throw new IllegalStateException("Should never occur"); } } public void enter(){ if(this.appValue != null) throw new IllegalStateException("Invalid application state"); this.appValue = new XmlApplicationValue(); } public void exit(){ this.applicationList.add(this.appValue); this.appValue = null; } }