org.cqframework.cql.elm.execution.IncludedIn Maven / Gradle / Ivy
//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.11
// See http://java.sun.com/xml/jaxb
// Any modifications to this file will be lost upon recompilation of the source schema.
// Generated on: 2018.04.13 at 05:43:32 PM MDT
//
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.Equals;
import org.jvnet.jaxb2_commons.lang.EqualsStrategy;
import org.jvnet.jaxb2_commons.lang.HashCode;
import org.jvnet.jaxb2_commons.lang.HashCodeStrategy;
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.ToString;
import org.jvnet.jaxb2_commons.lang.ToStringStrategy;
import org.jvnet.jaxb2_commons.locator.ObjectLocator;
import org.jvnet.jaxb2_commons.locator.util.LocatorUtils;
/**
* The IncludedIn operator returns true if the first operand is completely included in the second.
*
* There are two overloads of this operator:
* List, List : The element type of both lists must be the same.
* Interval, Interval : The point type of both intervals must be the same.
*
* For the List, List overload, this operator returns true if every element in the first list is included in the second list, using equivalence semantics. If either argument is null, it should be treated as an empty list.
*
* For the Interval, Interval overload, this operator returns true if the starting point of the first interval is greater than or equal to the starting point of the second interval, and the ending point of the first interval is less than or equal to the ending point of the second interval. If either argument is null, the result is null. If precision is specified and the point type is a date/time type, comparisons used in the operation are performed at the specified precision.
*
* This operator uses the semantics described in the Start and End operators to determine interval boundaries.
*
* Java class for IncludedIn complex type.
*
*
The following schema fragment specifies the expected content contained within this class.
*
*
* <complexType name="IncludedIn">
* <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 = "IncludedIn", namespace = "urn:hl7-org:elm:r1")
public class IncludedIn
extends BinaryExpression
implements Equals, HashCode, ToString
{
@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 IncludedIn withPrecision(DateTimePrecision value) {
setPrecision(value);
return this;
}
@Override
public IncludedIn withOperand(Expression... values) {
if (values!= null) {
for (Expression value: values) {
getOperand().add(value);
}
}
return this;
}
@Override
public IncludedIn withOperand(Collection values) {
if (values!= null) {
getOperand().addAll(values);
}
return this;
}
@Override
public IncludedIn withAnnotation(Object... values) {
if (values!= null) {
for (Object value: values) {
getAnnotation().add(value);
}
}
return this;
}
@Override
public IncludedIn withAnnotation(Collection