All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.cqframework.cql.elm.execution.Contains Maven / Gradle / Ivy

The newest version!
//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.3.0 
// See https://javaee.github.io/jaxb-v2/ 
// Any modifications to this file will be lost upon recompilation of the source schema. 
// Generated on: 2022.01.10 at 12:41:52 PM MST 
//


package org.cqframework.cql.elm.execution;

import java.util.Collection;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlType;
import javax.xml.namespace.QName;
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.JAXBEqualsStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBHashCodeStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBToStringStrategy;
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;


/**
 * The Contains operator returns true if the first operand contains the second.
 * 
 * There are two overloads of this operator:
 * 	List, T : The type of T must be the same as the element type of the list.
 * 	Interval, T : The type of T must be the same as the point type of the interval.
 * 
 * For the List, T overload, this operator returns true if the given element is in the list, using equality semantics.
 * 
 * For the Interval, T overload, this operator returns true if the given point is greater than or equal to the starting point of the interval, and less than or equal to the ending point of the interval. For open interval boundaries, exclusive comparison operators are used. For closed interval boundaries, if the interval boundary is null, the result of the boundary comparison is considered true. If precision is specified and the point type is a Date, DateTime, or Time type, comparisons used in the operation are performed at the specified precision.
 * 
 * If the first argument is null, the result is false. If the second argument is null, the result is null.
 * 
 * 

Java class for Contains complex type. * *

The following schema fragment specifies the expected content contained within this class. * *

 * <complexType name="Contains">
 *   <complexContent>
 *     <extension base="{urn:hl7-org:elm:r1}BinaryExpression">
 *       <attribute name="precision" type="{urn:hl7-org:elm:r1}DateTimePrecision" />
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "Contains", namespace = "urn:hl7-org:elm:r1") @SuppressWarnings({ "all" }) public class Contains extends BinaryExpression implements Equals2, HashCode2, ToString2 { @XmlAttribute(name = "precision") protected DateTimePrecision precision; /** * Gets the value of the precision property. * * @return * possible object is * {@link DateTimePrecision } * */ public DateTimePrecision getPrecision() { return precision; } /** * Sets the value of the precision property. * * @param value * allowed object is * {@link DateTimePrecision } * */ public void setPrecision(DateTimePrecision value) { this.precision = value; } public Contains withPrecision(DateTimePrecision value) { setPrecision(value); return this; } @Override public Contains withOperand(Expression... values) { if (values!= null) { for (Expression value: values) { getOperand().add(value); } } return this; } @Override public Contains withOperand(Collection values) { if (values!= null) { getOperand().addAll(values); } return this; } @Override public Contains withSignature(TypeSpecifier... values) { if (values!= null) { for (TypeSpecifier value: values) { getSignature().add(value); } } return this; } @Override public Contains withSignature(Collection values) { if (values!= null) { getSignature().addAll(values); } return this; } @Override public Contains withAnnotation(Object... values) { if (values!= null) { for (Object value: values) { getAnnotation().add(value); } } return this; } @Override public Contains withAnnotation(Collection values) { if (values!= null) { getAnnotation().addAll(values); } return this; } @Override public Contains withResultTypeSpecifier(TypeSpecifier value) { setResultTypeSpecifier(value); return this; } @Override public Contains withLocalId(String value) { setLocalId(value); return this; } @Override public Contains withLocator(String value) { setLocator(value); return this; } @Override public Contains withResultTypeName(QName value) { setResultTypeName(value); return this; } 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 Contains that = ((Contains) object); { DateTimePrecision lhsPrecision; lhsPrecision = this.getPrecision(); DateTimePrecision rhsPrecision; rhsPrecision = that.getPrecision(); if (!strategy.equals(LocatorUtils.property(thisLocator, "precision", lhsPrecision), LocatorUtils.property(thatLocator, "precision", rhsPrecision), lhsPrecision, rhsPrecision, (this.precision!= null), (that.precision!= null))) { return false; } } return true; } public boolean equals(Object object) { final EqualsStrategy2 strategy = JAXBEqualsStrategy.INSTANCE2; return equals(null, null, object, strategy); } public int hashCode(ObjectLocator locator, HashCodeStrategy2 strategy) { int currentHashCode = super.hashCode(locator, strategy); { DateTimePrecision thePrecision; thePrecision = this.getPrecision(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "precision", thePrecision), currentHashCode, thePrecision, (this.precision!= null)); } return currentHashCode; } public int hashCode() { final HashCodeStrategy2 strategy = JAXBHashCodeStrategy.INSTANCE2; return this.hashCode(null, strategy); } public String toString() { final ToStringStrategy2 strategy = JAXBToStringStrategy.INSTANCE2; 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); { DateTimePrecision thePrecision; thePrecision = this.getPrecision(); strategy.appendField(locator, this, "precision", buffer, thePrecision, (this.precision!= null)); } return buffer; } }