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

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

//
// 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: 2020.03.24 at 04:05:23 PM UTC 
//


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 OverlapsAfter operator returns true if the first interval overlaps and ends after the second. In other words, if the starting point of the first interval contains the ending point of the second interval.
 * 			
 * This operator uses the semantics described in the Start and End operators to determine interval boundaries.
 * 
 * If precision is specified and the point type is a date/time type, comparisons used in the operation are performed at the specified precision.
 *  
 * If either argument is null, the result is null.
 * 
 * 

Java class for OverlapsAfter complex type. * *

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

 * <complexType name="OverlapsAfter">
 *   <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 = "OverlapsAfter", namespace = "urn:hl7-org:elm:r1") public class OverlapsAfter 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 OverlapsAfter withPrecision(DateTimePrecision value) { setPrecision(value); return this; } @Override public OverlapsAfter withOperand(Expression... values) { if (values!= null) { for (Expression value: values) { getOperand().add(value); } } return this; } @Override public OverlapsAfter withOperand(Collection values) { if (values!= null) { getOperand().addAll(values); } return this; } @Override public OverlapsAfter withSignature(TypeSpecifier... values) { if (values!= null) { for (TypeSpecifier value: values) { getSignature().add(value); } } return this; } @Override public OverlapsAfter withSignature(Collection values) { if (values!= null) { getSignature().addAll(values); } return this; } @Override public OverlapsAfter withAnnotation(Object... values) { if (values!= null) { for (Object value: values) { getAnnotation().add(value); } } return this; } @Override public OverlapsAfter withAnnotation(Collection values) { if (values!= null) { getAnnotation().addAll(values); } return this; } @Override public OverlapsAfter withResultTypeSpecifier(TypeSpecifier value) { setResultTypeSpecifier(value); return this; } @Override public OverlapsAfter withLocalId(String value) { setLocalId(value); return this; } @Override public OverlapsAfter withLocator(String value) { setLocator(value); return this; } @Override public OverlapsAfter withResultTypeName(QName value) { setResultTypeName(value); return this; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof OverlapsAfter)) { return false; } if (this == object) { return true; } if (!super.equals(thisLocator, thatLocator, object, strategy)) { return false; } final OverlapsAfter that = ((OverlapsAfter) 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)) { return false; } } return true; } public boolean equals(Object object) { final EqualsStrategy strategy = JAXBEqualsStrategy.INSTANCE; return equals(null, null, object, strategy); } public int hashCode(ObjectLocator locator, HashCodeStrategy strategy) { int currentHashCode = super.hashCode(locator, strategy); { DateTimePrecision thePrecision; thePrecision = this.getPrecision(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "precision", thePrecision), currentHashCode, thePrecision); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } 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); { DateTimePrecision thePrecision; thePrecision = this.getPrecision(); strategy.appendField(locator, this, "precision", buffer, thePrecision); } return buffer; } }