/**
*
* geo-platform
* Rich webgis framework
* http://geo-platform.org
* ====================================================================
*
* Copyright (C) 2008-2017 geoSDI Group (CNR IMAA - Potenza - ITALY).
*
* This program 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. 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, see http://www.gnu.org/licenses/
*
* ====================================================================
*
* Linking this library statically or dynamically with other modules is
* making a combined work based on this library. Thus, the terms and
* conditions of the GNU General Public License cover the whole combination.
*
* As a special exception, the copyright holders of this library give you permission
* to link this library with independent modules to produce an executable, regardless
* of the license terms of these independent modules, and to copy and distribute
* the resulting executable under terms of your choice, provided that you also meet,
* for each linked independent module, the terms and conditions of the license of
* that module. An independent module is a module which is not derived from or
* based on this library. If you modify this library, you may extend this exception
* to your version of the library, but you are not obligated to do so. If you do not
* wish to do so, delete this exception statement from your version.
*/
//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.5-b10
// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
// Any modifications to this file will be lost upon recompilation of the source schema.
// Generated on: 2012.04.18 at 03:12:11 PM CEST
//
package org.geosdi.geoplatform.xml.iso19139.v20070417.gmd;
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlType;
import org.geosdi.geoplatform.xml.iso19139.v20070417.gco.CharacterStringPropertyType;
import org.jvnet.jaxb2_commons.lang.JAXBToStringStrategy;
import org.jvnet.jaxb2_commons.lang.ToString;
import org.jvnet.jaxb2_commons.lang.ToStringStrategy;
import org.jvnet.jaxb2_commons.locator.ObjectLocator;
/**
* <p>Java class for MD_DataIdentification_Type complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="MD_DataIdentification_Type">
* <complexContent>
* <extension base="{http://www.isotc211.org/2005/gmd}AbstractMD_Identification_Type">
* <sequence>
* <element name="spatialRepresentationType" type="{http://www.isotc211.org/2005/gmd}MD_SpatialRepresentationTypeCode_PropertyType" maxOccurs="unbounded" minOccurs="0"/>
* <element name="spatialResolution" type="{http://www.isotc211.org/2005/gmd}MD_Resolution_PropertyType" maxOccurs="unbounded" minOccurs="0"/>
* <element name="language" type="{http://www.isotc211.org/2005/gco}CharacterString_PropertyType" maxOccurs="unbounded"/>
* <element name="characterSet" type="{http://www.isotc211.org/2005/gmd}MD_CharacterSetCode_PropertyType" maxOccurs="unbounded" minOccurs="0"/>
* <element name="topicCategory" type="{http://www.isotc211.org/2005/gmd}MD_TopicCategoryCode_PropertyType" maxOccurs="unbounded" minOccurs="0"/>
* <element name="environmentDescription" type="{http://www.isotc211.org/2005/gco}CharacterString_PropertyType" minOccurs="0"/>
* <element name="extent" type="{http://www.isotc211.org/2005/gmd}EX_Extent_PropertyType" maxOccurs="unbounded" minOccurs="0"/>
* <element name="supplementalInformation" type="{http://www.isotc211.org/2005/gco}CharacterString_PropertyType" minOccurs="0"/>
* </sequence>
* </extension>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "MD_DataIdentification_Type", propOrder = {
"spatialRepresentationType",
"spatialResolution",
"language",
"characterSet",
"topicCategory",
"environmentDescription",
"extent",
"supplementalInformation"
})
public class MDDataIdentificationType
extends AbstractMDIdentificationType
implements ToString
{
protected List<MDSpatialRepresentationTypeCodePropertyType> spatialRepresentationType;
protected List<MDResolutionPropertyType> spatialResolution;
@XmlElement(required = true)
protected List<CharacterStringPropertyType> language;
protected List<MDCharacterSetCodePropertyType> characterSet;
protected List<MDTopicCategoryCodePropertyType> topicCategory;
protected CharacterStringPropertyType environmentDescription;
protected List<EXExtentPropertyType> extent;
protected CharacterStringPropertyType supplementalInformation;
/**
* Gets the value of the spatialRepresentationType property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the spatialRepresentationType property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getSpatialRepresentationType().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link MDSpatialRepresentationTypeCodePropertyType }
*
*
*/
public List<MDSpatialRepresentationTypeCodePropertyType> getSpatialRepresentationType() {
if (spatialRepresentationType == null) {
spatialRepresentationType = new ArrayList<MDSpatialRepresentationTypeCodePropertyType>();
}
return this.spatialRepresentationType;
}
public boolean isSetSpatialRepresentationType() {
return ((this.spatialRepresentationType!= null)&&(!this.spatialRepresentationType.isEmpty()));
}
public void unsetSpatialRepresentationType() {
this.spatialRepresentationType = null;
}
/**
* Gets the value of the spatialResolution property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the spatialResolution property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getSpatialResolution().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link MDResolutionPropertyType }
*
*
*/
public List<MDResolutionPropertyType> getSpatialResolution() {
if (spatialResolution == null) {
spatialResolution = new ArrayList<MDResolutionPropertyType>();
}
return this.spatialResolution;
}
public boolean isSetSpatialResolution() {
return ((this.spatialResolution!= null)&&(!this.spatialResolution.isEmpty()));
}
public void unsetSpatialResolution() {
this.spatialResolution = null;
}
/**
* Gets the value of the language property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the language property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getLanguage().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link CharacterStringPropertyType }
*
*
*/
public List<CharacterStringPropertyType> getLanguage() {
if (language == null) {
language = new ArrayList<CharacterStringPropertyType>();
}
return this.language;
}
public boolean isSetLanguage() {
return ((this.language!= null)&&(!this.language.isEmpty()));
}
public void unsetLanguage() {
this.language = null;
}
/**
* Gets the value of the characterSet property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the characterSet property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getCharacterSet().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link MDCharacterSetCodePropertyType }
*
*
*/
public List<MDCharacterSetCodePropertyType> getCharacterSet() {
if (characterSet == null) {
characterSet = new ArrayList<MDCharacterSetCodePropertyType>();
}
return this.characterSet;
}
public boolean isSetCharacterSet() {
return ((this.characterSet!= null)&&(!this.characterSet.isEmpty()));
}
public void unsetCharacterSet() {
this.characterSet = null;
}
/**
* Gets the value of the topicCategory property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the topicCategory property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getTopicCategory().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link MDTopicCategoryCodePropertyType }
*
*
*/
public List<MDTopicCategoryCodePropertyType> getTopicCategory() {
if (topicCategory == null) {
topicCategory = new ArrayList<MDTopicCategoryCodePropertyType>();
}
return this.topicCategory;
}
public boolean isSetTopicCategory() {
return ((this.topicCategory!= null)&&(!this.topicCategory.isEmpty()));
}
public void unsetTopicCategory() {
this.topicCategory = null;
}
/**
* Gets the value of the environmentDescription property.
*
* @return
* possible object is
* {@link CharacterStringPropertyType }
*
*/
public CharacterStringPropertyType getEnvironmentDescription() {
return environmentDescription;
}
/**
* Sets the value of the environmentDescription property.
*
* @param value
* allowed object is
* {@link CharacterStringPropertyType }
*
*/
public void setEnvironmentDescription(CharacterStringPropertyType value) {
this.environmentDescription = value;
}
public boolean isSetEnvironmentDescription() {
return (this.environmentDescription!= null);
}
/**
* Gets the value of the extent property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the extent property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getExtent().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link EXExtentPropertyType }
*
*
*/
public List<EXExtentPropertyType> getExtent() {
if (extent == null) {
extent = new ArrayList<EXExtentPropertyType>();
}
return this.extent;
}
public boolean isSetExtent() {
return ((this.extent!= null)&&(!this.extent.isEmpty()));
}
public void unsetExtent() {
this.extent = null;
}
/**
* Gets the value of the supplementalInformation property.
*
* @return
* possible object is
* {@link CharacterStringPropertyType }
*
*/
public CharacterStringPropertyType getSupplementalInformation() {
return supplementalInformation;
}
/**
* Sets the value of the supplementalInformation property.
*
* @param value
* allowed object is
* {@link CharacterStringPropertyType }
*
*/
public void setSupplementalInformation(CharacterStringPropertyType value) {
this.supplementalInformation = value;
}
public boolean isSetSupplementalInformation() {
return (this.supplementalInformation!= null);
}
public String toString() {
final ToStringStrategy strategy = JAXBToStringStrategy.INSTANCE;
final StringBuilder buffer = new StringBuilder();
append(null, buffer, strategy);
return buffer.toString();
}
public StringBuilder append(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) {
strategy.appendStart(locator, this, buffer);
appendFields(locator, buffer, strategy);
strategy.appendEnd(locator, this, buffer);
return buffer;
}
public StringBuilder appendFields(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) {
super.appendFields(locator, buffer, strategy);
{
List<MDSpatialRepresentationTypeCodePropertyType> theSpatialRepresentationType;
theSpatialRepresentationType = (this.isSetSpatialRepresentationType()?this.getSpatialRepresentationType():null);
strategy.appendField(locator, this, "spatialRepresentationType", buffer, theSpatialRepresentationType);
}
{
List<MDResolutionPropertyType> theSpatialResolution;
theSpatialResolution = (this.isSetSpatialResolution()?this.getSpatialResolution():null);
strategy.appendField(locator, this, "spatialResolution", buffer, theSpatialResolution);
}
{
List<CharacterStringPropertyType> theLanguage;
theLanguage = (this.isSetLanguage()?this.getLanguage():null);
strategy.appendField(locator, this, "language", buffer, theLanguage);
}
{
List<MDCharacterSetCodePropertyType> theCharacterSet;
theCharacterSet = (this.isSetCharacterSet()?this.getCharacterSet():null);
strategy.appendField(locator, this, "characterSet", buffer, theCharacterSet);
}
{
List<MDTopicCategoryCodePropertyType> theTopicCategory;
theTopicCategory = (this.isSetTopicCategory()?this.getTopicCategory():null);
strategy.appendField(locator, this, "topicCategory", buffer, theTopicCategory);
}
{
CharacterStringPropertyType theEnvironmentDescription;
theEnvironmentDescription = this.getEnvironmentDescription();
strategy.appendField(locator, this, "environmentDescription", buffer, theEnvironmentDescription);
}
{
List<EXExtentPropertyType> theExtent;
theExtent = (this.isSetExtent()?this.getExtent():null);
strategy.appendField(locator, this, "extent", buffer, theExtent);
}
{
CharacterStringPropertyType theSupplementalInformation;
theSupplementalInformation = this.getSupplementalInformation();
strategy.appendField(locator, this, "supplementalInformation", buffer, theSupplementalInformation);
}
return buffer;
}
public void setSpatialRepresentationType(List<MDSpatialRepresentationTypeCodePropertyType> value) {
this.spatialRepresentationType = null;
List<MDSpatialRepresentationTypeCodePropertyType> draftl = this.getSpatialRepresentationType();
draftl.addAll(value);
}
public void setSpatialResolution(List<MDResolutionPropertyType> value) {
this.spatialResolution = null;
List<MDResolutionPropertyType> draftl = this.getSpatialResolution();
draftl.addAll(value);
}
public void setLanguage(List<CharacterStringPropertyType> value) {
this.language = null;
List<CharacterStringPropertyType> draftl = this.getLanguage();
draftl.addAll(value);
}
public void setCharacterSet(List<MDCharacterSetCodePropertyType> value) {
this.characterSet = null;
List<MDCharacterSetCodePropertyType> draftl = this.getCharacterSet();
draftl.addAll(value);
}
public void setTopicCategory(List<MDTopicCategoryCodePropertyType> value) {
this.topicCategory = null;
List<MDTopicCategoryCodePropertyType> draftl = this.getTopicCategory();
draftl.addAll(value);
}
public void setExtent(List<EXExtentPropertyType> value) {
this.extent = null;
List<EXExtentPropertyType> draftl = this.getExtent();
draftl.addAll(value);
}
}