/* * JAME 6.2.1 * http://jame.sourceforge.net * * Copyright 2001, 2016 Andrea Medeghini * * This file is part of JAME. * * JAME is an application for creating fractals and other graphics artifacts. * * JAME is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * JAME 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 JAME. If not, see <http://www.gnu.org/licenses/>. * */ package net.sf.jame.core.config; import net.sf.jame.core.xml.XML; import net.sf.jame.core.xml.XMLExportException; import net.sf.jame.core.xml.XMLExporter; import net.sf.jame.core.xml.XMLNodeBuilder; import org.w3c.dom.Element; import java.io.Serializable; /** * Abstract value element exporter. * * @author Andrea Medeghini */ public abstract class ValueConfigElementXMLExporter<V extends Serializable, T extends ValueConfigElement<V>> extends XMLExporter<T> { /** * @see net.sf.jame.core.xml.XMLExporter#exportToElement(java.lang.Object, net.sf.jame.core.xml.XMLNodeBuilder) */ @Override public Element exportToElement(final T configElement, final XMLNodeBuilder builder) throws XMLExportException { final Element element = this.createElement(builder, configElement.getClassId()); this.exportProperties(configElement, element, builder); return element; } /** * @param configElement * @param element * @param builder * @throws XMLExportException */ protected void exportProperties(final T configElement, final Element element, final XMLNodeBuilder builder) throws XMLExportException { this.exportValue(configElement, createProperty(builder, element, "value"), builder); } /** * @param configElement * @param element * @param builder * @throws XMLExportException */ protected void exportValue(final T configElement, final Element element, final XMLNodeBuilder builder) throws XMLExportException { element.appendChild(XML.createStringElement(builder, "value", this.formatValue(configElement.getValue()))); } /** * Formats the value. * * @param value the value. * @return the formatted value. */ protected abstract String formatValue(V value); }