/*
* 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.common;
import net.sf.jame.core.CoreRegistry;
import net.sf.jame.core.extension.Extension;
import net.sf.jame.core.extension.ExtensionConfig;
import net.sf.jame.core.extension.ExtensionException;
import net.sf.jame.core.extensionConfigXMLExporter.extension.ExtensionConfigXMLExporterExtensionRuntime;
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;
/**
* @author Andrea Medeghini
*/
public class ConfigurableExtensionReferenceElementXMLExporter<V extends ExtensionConfig> extends XMLExporter<ConfigurableExtensionReferenceElement<V>> {
/**
* @see net.sf.jame.core.xml.XMLExporter#exportToElement(java.lang.Object, net.sf.jame.core.xml.XMLNodeBuilder)
*/
@Override
public Element exportToElement(final ConfigurableExtensionReferenceElement<V> configElement, final XMLNodeBuilder builder) throws XMLExportException {
if (configElement.getReference() != null) {
final String extensionId = configElement.getReference().getExtensionId();
final Element element = this.createElement(builder, configElement.getClassId(), extensionId);
try {
this.exportProperties(configElement, element, builder, extensionId);
}
catch (final ExtensionException e) {
throw new XMLExportException(e);
}
return element;
}
else {
return this.createElement(builder, configElement.getClassId());
}
}
/**
* @param configElement
* @param element
* @param builder
* @param extensionId
* @throws ExtensionException
* @throws XMLExportException
*/
protected void exportProperties(final ConfigurableExtensionReferenceElement<V> configElement, final Element element, final XMLNodeBuilder builder, final String extensionId) throws ExtensionException, XMLExportException {
this.exportReference(configElement, createProperty(builder, element, "extensionConfig"), builder, extensionId);
}
/**
* @param configElement
* @param element
* @param builder
* @param extensionId
* @throws ExtensionException
* @throws XMLExportException
*/
@SuppressWarnings("unchecked")
protected void exportReference(final ConfigurableExtensionReferenceElement<V> configElement, final Element element, final XMLNodeBuilder builder, final String extensionId) throws ExtensionException, XMLExportException {
final Extension<ExtensionConfigXMLExporterExtensionRuntime> exporterExtension = CoreRegistry.getInstance().getXMLExtensionConfigExporterExtension(extensionId);
final XMLExporter<V> exporter = (XMLExporter<V>) (exporterExtension.createExtensionRuntime()).createXMLExporter();
element.appendChild(exporter.exportToElement(configElement.getReference().getExtensionConfig(), builder));
}
}