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

org.cqframework.cql.elm.execution.AggregateExpression 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.ArrayList;
import java.util.Collection;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlSeeAlso;
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;


/**
 * Aggregate expressions perform operations on lists of data, either directly on a list of scalars, or indirectly on a list of objects, with a reference to a property present on each object in the list.
 * 			
 * Aggregate expressions deal with missing information by excluding missing values from consideration before performing the aggregated operation. For example, in a Sum over Dose, any instance of Medication with no value for Dose would be ignored.
 * 
 * An aggregate operation performed over an empty list is defined to return null, except as noted in the documentation for each operator (Count, AllTrue, and AnyTrue are the exceptions).
 * 
 * 

Java class for AggregateExpression complex type. * *

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

 * <complexType name="AggregateExpression">
 *   <complexContent>
 *     <extension base="{urn:hl7-org:elm:r1}Expression">
 *       <sequence>
 *         <element name="signature" type="{urn:hl7-org:elm:r1}TypeSpecifier" maxOccurs="unbounded" minOccurs="0"/>
 *         <element name="source" type="{urn:hl7-org:elm:r1}Expression"/>
 *       </sequence>
 *       <attribute name="path" type="{http://www.w3.org/2001/XMLSchema}string" />
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "AggregateExpression", namespace = "urn:hl7-org:elm:r1", propOrder = { "signature", "source" }) @XmlSeeAlso({ Aggregate.class, Count.class, Sum.class, Product.class, Min.class, Max.class, Avg.class, GeometricMean.class, Median.class, Mode.class, Variance.class, PopulationVariance.class, StdDev.class, PopulationStdDev.class, AllTrue.class, AnyTrue.class }) public abstract class AggregateExpression extends Expression implements Equals, HashCode, ToString { @XmlElement(namespace = "urn:hl7-org:elm:r1") protected List signature; @XmlElement(namespace = "urn:hl7-org:elm:r1", required = true) protected Expression source; @XmlAttribute(name = "path") protected String path; /** * Gets the value of the signature property. * *

* This accessor method returns a reference to the live list, * not a snapshot. Therefore any modification you make to the * returned list will be present inside the JAXB object. * This is why there is not a set method for the signature property. * *

* For example, to add a new item, do as follows: *

     *    getSignature().add(newItem);
     * 
* * *

* Objects of the following type(s) are allowed in the list * {@link TypeSpecifier } * * */ public List getSignature() { if (signature == null) { signature = new ArrayList(); } return this.signature; } /** * Gets the value of the source property. * * @return * possible object is * {@link Expression } * */ public Expression getSource() { return source; } /** * Sets the value of the source property. * * @param value * allowed object is * {@link Expression } * */ public void setSource(Expression value) { this.source = value; } /** * Gets the value of the path property. * * @return * possible object is * {@link String } * */ public String getPath() { return path; } /** * Sets the value of the path property. * * @param value * allowed object is * {@link String } * */ public void setPath(String value) { this.path = value; } public AggregateExpression withSignature(TypeSpecifier... values) { if (values!= null) { for (TypeSpecifier value: values) { getSignature().add(value); } } return this; } public AggregateExpression withSignature(Collection values) { if (values!= null) { getSignature().addAll(values); } return this; } public AggregateExpression withSource(Expression value) { setSource(value); return this; } public AggregateExpression withPath(String value) { setPath(value); return this; } @Override public AggregateExpression withAnnotation(Object... values) { if (values!= null) { for (Object value: values) { getAnnotation().add(value); } } return this; } @Override public AggregateExpression withAnnotation(Collection values) { if (values!= null) { getAnnotation().addAll(values); } return this; } @Override public AggregateExpression withResultTypeSpecifier(TypeSpecifier value) { setResultTypeSpecifier(value); return this; } @Override public AggregateExpression withLocalId(String value) { setLocalId(value); return this; } @Override public AggregateExpression withLocator(String value) { setLocator(value); return this; } @Override public AggregateExpression withResultTypeName(QName value) { setResultTypeName(value); return this; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof AggregateExpression)) { return false; } if (this == object) { return true; } if (!super.equals(thisLocator, thatLocator, object, strategy)) { return false; } final AggregateExpression that = ((AggregateExpression) object); { List lhsSignature; lhsSignature = (((this.signature!= null)&&(!this.signature.isEmpty()))?this.getSignature():null); List rhsSignature; rhsSignature = (((that.signature!= null)&&(!that.signature.isEmpty()))?that.getSignature():null); if (!strategy.equals(LocatorUtils.property(thisLocator, "signature", lhsSignature), LocatorUtils.property(thatLocator, "signature", rhsSignature), lhsSignature, rhsSignature)) { return false; } } { Expression lhsSource; lhsSource = this.getSource(); Expression rhsSource; rhsSource = that.getSource(); if (!strategy.equals(LocatorUtils.property(thisLocator, "source", lhsSource), LocatorUtils.property(thatLocator, "source", rhsSource), lhsSource, rhsSource)) { return false; } } { String lhsPath; lhsPath = this.getPath(); String rhsPath; rhsPath = that.getPath(); if (!strategy.equals(LocatorUtils.property(thisLocator, "path", lhsPath), LocatorUtils.property(thatLocator, "path", rhsPath), lhsPath, rhsPath)) { 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); { List theSignature; theSignature = (((this.signature!= null)&&(!this.signature.isEmpty()))?this.getSignature():null); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "signature", theSignature), currentHashCode, theSignature); } { Expression theSource; theSource = this.getSource(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "source", theSource), currentHashCode, theSource); } { String thePath; thePath = this.getPath(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "path", thePath), currentHashCode, thePath); } 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); { List theSignature; theSignature = (((this.signature!= null)&&(!this.signature.isEmpty()))?this.getSignature():null); strategy.appendField(locator, this, "signature", buffer, theSignature); } { Expression theSource; theSource = this.getSource(); strategy.appendField(locator, this, "source", buffer, theSource); } { String thePath; thePath = this.getPath(); strategy.appendField(locator, this, "path", buffer, thePath); } return buffer; } }