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

org.hl7.elm.r1.SameOrAfter Maven / Gradle / Ivy

Go to download

The elm library for the Clinical Quality Language Java reference implementation

There is a newer version: 3.18.0
Show newest version
//
// This file was generated by the Eclipse Implementation of JAXB, v3.0.2 
// See https://eclipse-ee4j.github.io/jaxb-ri 
// Any modifications to this file will be lost upon recompilation of the source schema. 
// Generated on: 2024.10.07 at 09:31:22 AM MDT 
//


package org.hl7.elm.r1;

import java.util.Collection;
import javax.xml.namespace.QName;
import jakarta.xml.bind.annotation.XmlAccessType;
import jakarta.xml.bind.annotation.XmlAccessorType;
import jakarta.xml.bind.annotation.XmlAttribute;
import jakarta.xml.bind.annotation.XmlType;
import org.hl7.cql_annotations.r1.CqlToElmBase;
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 SameOrAfter operator is defined for Date, DateTime, and Time values, as well as intervals.
 * 
 * For the Interval overload, the SameOrAfter operator returns true if the first interval starts on or after the second one ends. In other words, if the starting point of the first interval is greater than or equal to the ending point of the second interval, using the semantics described in the Start and End operators to determine interval boundaries.
 * 
 * For the Date, DateTime, and Time overloads, this operator compares two Date, DateTime, or Time values to the specified precision to determine whether the first argument is the same or after the second argument. The comparison is performed by considering each precision in order, beginning with years (or hours for time values). If the values are the same, comparison proceeds to the next precision; if the first value is greater than the second, the result is true; if the first value is less than the second, the result is false; if either input has no value for the precision, the comparison stops and the result is null; if the specified precision has been reached, the comparison stops and the result is true.
 * 
 * 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.
 * 
 * When comparing DateTime values with different timezone offsets, implementations should normalize to the timezone offset of the evaluation request timestamp, but only when the comparison precision is hours, minutes, seconds, or milliseconds.
 * 
 * If either argument is null, the result is null.
 * 
 * 

Java class for SameOrAfter complex type. * *

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

 * <complexType name="SameOrAfter">
 *   <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 = "SameOrAfter", namespace = "urn:hl7-org:elm:r1") public class SameOrAfter 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 SameOrAfter withPrecision(DateTimePrecision value) { setPrecision(value); return this; } @Override public SameOrAfter withOperand(Expression... values) { if (values!= null) { for (Expression value: values) { getOperand().add(value); } } return this; } @Override public SameOrAfter withOperand(Collection values) { if (values!= null) { getOperand().addAll(values); } return this; } @Override public SameOrAfter withSignature(TypeSpecifier... values) { if (values!= null) { for (TypeSpecifier value: values) { getSignature().add(value); } } return this; } @Override public SameOrAfter withSignature(Collection values) { if (values!= null) { getSignature().addAll(values); } return this; } @Override public SameOrAfter withAnnotation(CqlToElmBase... values) { if (values!= null) { for (CqlToElmBase value: values) { getAnnotation().add(value); } } return this; } @Override public SameOrAfter withAnnotation(Collection values) { if (values!= null) { getAnnotation().addAll(values); } return this; } @Override public SameOrAfter withResultTypeSpecifier(TypeSpecifier value) { setResultTypeSpecifier(value); return this; } @Override public SameOrAfter withLocalId(String value) { setLocalId(value); return this; } @Override public SameOrAfter withLocator(String value) { setLocator(value); return this; } @Override public SameOrAfter withResultTypeName(QName value) { setResultTypeName(value); return this; } @Override 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 SameOrAfter that = ((SameOrAfter) 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; } @Override public boolean equals(Object object) { final EqualsStrategy2 strategy = JAXBEqualsStrategy.getInstance(); return equals(null, null, object, strategy); } @Override 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; } @Override public int hashCode() { final HashCodeStrategy2 strategy = JAXBHashCodeStrategy.getInstance(); return this.hashCode(null, strategy); } @Override public String toString() { final ToStringStrategy2 strategy = JAXBToStringStrategy.getInstance(); final StringBuilder buffer = new StringBuilder(); append(null, buffer, strategy); return buffer.toString(); } @Override 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; } @Override 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; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy