org.geotoolkit.internal.jaxb.metadata.MD_Usage 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) 2008-2011, Open Source Geospatial Foundation (OSGeo)
* (C) 2009-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.metadata;
import javax.xml.bind.annotation.XmlElementRef;
import org.opengis.metadata.identification.Usage;
import org.geotoolkit.metadata.iso.identification.DefaultUsage;
import org.geotoolkit.internal.jaxb.gco.PropertyType;
/**
* JAXB adapter mapping implementing class to the GeoAPI interface. See
* package documentation for more information about JAXB and interface.
*
* @author Cédric Briançon (Geomatys)
* @author Martin Desruisseaux (Geomatys)
* @version 3.18
*
* @since 2.5
* @module
*/
public final class MD_Usage extends PropertyType {
/**
* Empty constructor for JAXB only.
*/
public MD_Usage() {
}
/**
* Wraps an Usage value with a {@code MD_Usage} element at marshalling time.
*
* @param metadata The metadata value to marshall.
*/
private MD_Usage(final Usage metadata) {
super(metadata);
}
/**
* Returns the Usage value wrapped by a {@code MD_Usage} element.
*
* @param value The value to marshall.
* @return The adapter which wraps the metadata value.
*/
@Override
protected MD_Usage wrap(final Usage value) {
return new MD_Usage(value);
}
/**
* Returns the GeoAPI interface which is bound by this adapter.
*/
@Override
protected Class getBoundType() {
return Usage.class;
}
/**
* Returns the {@link DefaultUsage} generated from the metadata value.
* This method is systematically called at marshalling time by JAXB.
*
* @return The metadata to be marshalled.
*/
@Override
@XmlElementRef
public DefaultUsage getElement() {
return skip() ? null : DefaultUsage.castOrCopy(metadata);
}
/**
* Sets the value for the {@link DefaultUsage}. This method is systematically
* called at unmarshalling time by JAXB.
*
* @param metadata The unmarshalled metadata.
*/
public void setElement(final DefaultUsage metadata) {
this.metadata = metadata;
}
}