org.geotoolkit.internal.jaxb.gmi.LE_Source Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of geotk-metadata Show documentation
Show all versions of geotk-metadata Show documentation
Implementations of metadata derived from ISO 19115. This module provides both an implementation
of the metadata interfaces defined in GeoAPI, and a framework for handling those metadata through
Java reflection.
/*
* Geotoolkit.org - An Open Source Java GIS Toolkit
* http://www.geotoolkit.org
*
* (C) 2010-2011, Open Source Geospatial Foundation (OSGeo)
* (C) 2010-2011, Geomatys
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License.
*
* This library 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
* Lesser General Public License for more details.
*/
package org.geotoolkit.internal.jaxb.gmi;
import javax.xml.bind.annotation.XmlType;
import javax.xml.bind.annotation.XmlRootElement;
import org.opengis.metadata.lineage.Source;
import org.geotoolkit.metadata.iso.lineage.DefaultSource;
/**
* A wrapper for a metadata using the {@code "gmi"} namespace.
*
* @author Guilhem Legal (Geomatys)
* @author Martin Desruisseaux (Geomatys)
* @version 3.17
*
* @since 3.17
* @module
*/
@XmlType(name = "LE_Source_Type")
@XmlRootElement(name = "LE_Source")
public class LE_Source extends DefaultSource {
/**
* For cross-version compatibility.
*/
private static final long serialVersionUID = -8237367019409009341L;
/**
* Creates an initially empty metadata.
* This is also the default constructor used by JAXB.
*/
public LE_Source() {
}
/**
* Creates a new metadata as a copy of the given one.
* This is a shallow copy constructor.
*
* @param original The original metadata to copy.
*/
public LE_Source(final Source original) {
super(original);
}
/**
* Wraps the given metadata into a Geotk implementation that can be marshalled,
* using the {@code "gmi"} namespace if necessary.
*
* @param original The original metadata provided by the user.
* @return The metadata to marshall.
*/
public static DefaultSource wrap(final Source original) {
if (original != null && !(original instanceof LE_Source)) {
if (original.getProcessedLevel() != null || original.getResolution() != null) {
return new LE_Source(original);
}
}
return DefaultSource.wrap(original);
}
}