// // 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); } } }