//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.11
// 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: 2016.07.27 at 04:06:37 PM EDT
//
package org.isotc211._2005.gmd;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import javax.validation.Valid;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlSeeAlso;
import javax.xml.bind.annotation.XmlType;
import org.isotc211._2005.gco.AbstractObjectType;
import org.isotc211._2005.gco.CharacterStringPropertyType;
import org.jvnet.jaxb2_commons.lang.CopyStrategy2;
import org.jvnet.jaxb2_commons.lang.CopyTo2;
import org.jvnet.jaxb2_commons.lang.Equals2;
import org.jvnet.jaxb2_commons.lang.EqualsStrategy2;
import org.jvnet.jaxb2_commons.lang.HashCode2;
import org.jvnet.jaxb2_commons.lang.HashCodeStrategy2;
import org.jvnet.jaxb2_commons.lang.JAXBCopyStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBEqualsStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBHashCodeStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBMergeStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBToStringStrategy;
import org.jvnet.jaxb2_commons.lang.MergeFrom2;
import org.jvnet.jaxb2_commons.lang.MergeStrategy2;
import org.jvnet.jaxb2_commons.lang.ToString2;
import org.jvnet.jaxb2_commons.lang.ToStringStrategy2;
import org.jvnet.jaxb2_commons.locator.ObjectLocator;
import org.jvnet.jaxb2_commons.locator.util.LocatorUtils;
/**
* Restrictions on the access and use of a dataset or metadata
*
* <p>Java class for MD_Constraints_Type complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="MD_Constraints_Type">
* <complexContent>
* <extension base="{http://www.isotc211.org/2005/gco}AbstractObject_Type">
* <sequence>
* <element name="useLimitation" type="{http://www.isotc211.org/2005/gco}CharacterString_PropertyType" maxOccurs="unbounded" minOccurs="0"/>
* </sequence>
* </extension>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "MD_Constraints_Type", propOrder = {
"useLimitation"
})
@XmlSeeAlso({
MDLegalConstraintsType.class,
MDSecurityConstraintsType.class
})
public class MDConstraintsType
extends AbstractObjectType
implements Serializable, Cloneable, CopyTo2, Equals2, HashCode2, MergeFrom2, ToString2
{
private final static long serialVersionUID = 1L;
@Valid
protected List<CharacterStringPropertyType> useLimitation;
/**
* Gets the value of the useLimitation 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 useLimitation property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getUseLimitation().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link CharacterStringPropertyType }
*
*
*/
public List<CharacterStringPropertyType> getUseLimitation() {
if (useLimitation == null) {
useLimitation = new ArrayList<CharacterStringPropertyType>();
}
return this.useLimitation;
}
public boolean isSetUseLimitation() {
return ((this.useLimitation!= null)&&(!this.useLimitation.isEmpty()));
}
public void unsetUseLimitation() {
this.useLimitation = null;
}
public String toString() {
final ToStringStrategy2 strategy = JAXBToStringStrategy.INSTANCE;
final StringBuilder buffer = new StringBuilder();
append(null, buffer, strategy);
return buffer.toString();
}
public StringBuilder append(ObjectLocator locator, StringBuilder buffer, ToStringStrategy2 strategy) {
strategy.appendStart(locator, this, buffer);
appendFields(locator, buffer, strategy);
strategy.appendEnd(locator, this, buffer);
return buffer;
}
public StringBuilder appendFields(ObjectLocator locator, StringBuilder buffer, ToStringStrategy2 strategy) {
super.appendFields(locator, buffer, strategy);
{
List<CharacterStringPropertyType> theUseLimitation;
theUseLimitation = (this.isSetUseLimitation()?this.getUseLimitation():null);
strategy.appendField(locator, this, "useLimitation", buffer, theUseLimitation, this.isSetUseLimitation());
}
return buffer;
}
public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy2 strategy) {
if ((object == null)||(this.getClass()!= object.getClass())) {
return false;
}
if (this == object) {
return true;
}
if (!super.equals(thisLocator, thatLocator, object, strategy)) {
return false;
}
final MDConstraintsType that = ((MDConstraintsType) object);
{
List<CharacterStringPropertyType> lhsUseLimitation;
lhsUseLimitation = (this.isSetUseLimitation()?this.getUseLimitation():null);
List<CharacterStringPropertyType> rhsUseLimitation;
rhsUseLimitation = (that.isSetUseLimitation()?that.getUseLimitation():null);
if (!strategy.equals(LocatorUtils.property(thisLocator, "useLimitation", lhsUseLimitation), LocatorUtils.property(thatLocator, "useLimitation", rhsUseLimitation), lhsUseLimitation, rhsUseLimitation, this.isSetUseLimitation(), that.isSetUseLimitation())) {
return false;
}
}
return true;
}
public boolean equals(Object object) {
final EqualsStrategy2 strategy = JAXBEqualsStrategy.INSTANCE;
return equals(null, null, object, strategy);
}
public int hashCode(ObjectLocator locator, HashCodeStrategy2 strategy) {
int currentHashCode = super.hashCode(locator, strategy);
{
List<CharacterStringPropertyType> theUseLimitation;
theUseLimitation = (this.isSetUseLimitation()?this.getUseLimitation():null);
currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "useLimitation", theUseLimitation), currentHashCode, theUseLimitation, this.isSetUseLimitation());
}
return currentHashCode;
}
public int hashCode() {
final HashCodeStrategy2 strategy = JAXBHashCodeStrategy.INSTANCE;
return this.hashCode(null, strategy);
}
public Object clone() {
return copyTo(createNewInstance());
}
public Object copyTo(Object target) {
final CopyStrategy2 strategy = JAXBCopyStrategy.INSTANCE;
return copyTo(null, target, strategy);
}
public Object copyTo(ObjectLocator locator, Object target, CopyStrategy2 strategy) {
final Object draftCopy = ((target == null)?createNewInstance():target);
super.copyTo(locator, draftCopy, strategy);
if (draftCopy instanceof MDConstraintsType) {
final MDConstraintsType copy = ((MDConstraintsType) draftCopy);
{
Boolean useLimitationShouldBeCopiedAndSet = strategy.shouldBeCopiedAndSet(locator, this.isSetUseLimitation());
if (useLimitationShouldBeCopiedAndSet == Boolean.TRUE) {
List<CharacterStringPropertyType> sourceUseLimitation;
sourceUseLimitation = (this.isSetUseLimitation()?this.getUseLimitation():null);
@SuppressWarnings("unchecked")
List<CharacterStringPropertyType> copyUseLimitation = ((List<CharacterStringPropertyType> ) strategy.copy(LocatorUtils.property(locator, "useLimitation", sourceUseLimitation), sourceUseLimitation, this.isSetUseLimitation()));
copy.unsetUseLimitation();
if (copyUseLimitation!= null) {
List<CharacterStringPropertyType> uniqueUseLimitationl = copy.getUseLimitation();
uniqueUseLimitationl.addAll(copyUseLimitation);
}
} else {
if (useLimitationShouldBeCopiedAndSet == Boolean.FALSE) {
copy.unsetUseLimitation();
}
}
}
}
return draftCopy;
}
public Object createNewInstance() {
return new MDConstraintsType();
}
public void mergeFrom(Object left, Object right) {
final MergeStrategy2 strategy = JAXBMergeStrategy.INSTANCE;
mergeFrom(null, null, left, right, strategy);
}
public void mergeFrom(ObjectLocator leftLocator, ObjectLocator rightLocator, Object left, Object right, MergeStrategy2 strategy) {
super.mergeFrom(leftLocator, rightLocator, left, right, strategy);
if (right instanceof MDConstraintsType) {
final MDConstraintsType target = this;
final MDConstraintsType leftObject = ((MDConstraintsType) left);
final MDConstraintsType rightObject = ((MDConstraintsType) right);
{
Boolean useLimitationShouldBeMergedAndSet = strategy.shouldBeMergedAndSet(leftLocator, rightLocator, leftObject.isSetUseLimitation(), rightObject.isSetUseLimitation());
if (useLimitationShouldBeMergedAndSet == Boolean.TRUE) {
List<CharacterStringPropertyType> lhsUseLimitation;
lhsUseLimitation = (leftObject.isSetUseLimitation()?leftObject.getUseLimitation():null);
List<CharacterStringPropertyType> rhsUseLimitation;
rhsUseLimitation = (rightObject.isSetUseLimitation()?rightObject.getUseLimitation():null);
List<CharacterStringPropertyType> mergedUseLimitation = ((List<CharacterStringPropertyType> ) strategy.merge(LocatorUtils.property(leftLocator, "useLimitation", lhsUseLimitation), LocatorUtils.property(rightLocator, "useLimitation", rhsUseLimitation), lhsUseLimitation, rhsUseLimitation, leftObject.isSetUseLimitation(), rightObject.isSetUseLimitation()));
target.unsetUseLimitation();
if (mergedUseLimitation!= null) {
List<CharacterStringPropertyType> uniqueUseLimitationl = target.getUseLimitation();
uniqueUseLimitationl.addAll(mergedUseLimitation);
}
} else {
if (useLimitationShouldBeMergedAndSet == Boolean.FALSE) {
target.unsetUseLimitation();
}
}
}
}
}
public void setUseLimitation(List<CharacterStringPropertyType> value) {
this.useLimitation = null;
if (value!= null) {
List<CharacterStringPropertyType> draftl = this.getUseLimitation();
draftl.addAll(value);
}
}
}