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

org.cqframework.cql.elm.execution.SameAs 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 SameAs operator is defined for Date, DateTime, and Time values, as well as intervals.
 * 			
 * For the Interval overloads, the SameAs operator returns true if the intervals start and end at the same value, using the semantics described in the Start and End operator to determine interval boundaries.
 * 
 * The SameAs operator compares two date/time values to the specified precision for equality. Individual component values are compared starting from the year component down to the specified precision. If all values are specified and have the same value for each component, then the result is true. If a compared component is specified in both dates, but the values are not the same, then the result is false. Otherwise the result is null, as there is not enough information to make a determination. 
 * 			
 * If no precision is specified, the comparison is performed beginning with years (or hours for time values) and proceeding to the finest precision specified in either input.
 * 
 * For Date values, precision must be one of year, month, or day.
 * 
 * For DateTime values, precision must be one of year, month, day, hour, minute, second, or millisecond.
 * 
 * For Time values, precision must be one of hour, minute, second, or millisecond.
 * 
 * Note specifically that due to variability in the way week numbers are determined, comparisons involving weeks are not supported.
 * 
 * As with all date/time calculations, comparisons are performed respecting the timezone offset.
 * 
 * If either argument is null, the result is null.
 * 
 * 

Java class for SameAs complex type. * *

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

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