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

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

The newest version!
//
// 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: 2022.01.10 at 12:41:52 PM MST 
//


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.XmlElement;
import javax.xml.bind.annotation.XmlType;
import javax.xml.namespace.QName;
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 Combine operator combines a list of strings, optionally separating each string with the given separator.
 * 
 * If either argument is null the result is null.  If the source list is empty, the result is an empty string ('').
 * 
 * For consistency with aggregate operator behavior, null elements in the input list are ignored.
 * 
 * 

Java class for Combine complex type. * *

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

 * <complexType name="Combine">
 *   <complexContent>
 *     <extension base="{urn:hl7-org:elm:r1}OperatorExpression">
 *       <sequence>
 *         <element name="source" type="{urn:hl7-org:elm:r1}Expression"/>
 *         <element name="separator" type="{urn:hl7-org:elm:r1}Expression" minOccurs="0"/>
 *       </sequence>
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "Combine", namespace = "urn:hl7-org:elm:r1", propOrder = { "source", "separator" }) @SuppressWarnings({ "all" }) public class Combine extends OperatorExpression implements Equals2, HashCode2, ToString2 { @XmlElement(namespace = "urn:hl7-org:elm:r1", required = true) protected Expression source; @XmlElement(namespace = "urn:hl7-org:elm:r1") protected Expression separator; /** * 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 separator property. * * @return * possible object is * {@link Expression } * */ public Expression getSeparator() { return separator; } /** * Sets the value of the separator property. * * @param value * allowed object is * {@link Expression } * */ public void setSeparator(Expression value) { this.separator = value; } public Combine withSource(Expression value) { setSource(value); return this; } public Combine withSeparator(Expression value) { setSeparator(value); return this; } @Override public Combine withSignature(TypeSpecifier... values) { if (values!= null) { for (TypeSpecifier value: values) { getSignature().add(value); } } return this; } @Override public Combine withSignature(Collection values) { if (values!= null) { getSignature().addAll(values); } return this; } @Override public Combine withAnnotation(Object... values) { if (values!= null) { for (Object value: values) { getAnnotation().add(value); } } return this; } @Override public Combine withAnnotation(Collection values) { if (values!= null) { getAnnotation().addAll(values); } return this; } @Override public Combine withResultTypeSpecifier(TypeSpecifier value) { setResultTypeSpecifier(value); return this; } @Override public Combine withLocalId(String value) { setLocalId(value); return this; } @Override public Combine withLocator(String value) { setLocator(value); return this; } @Override public Combine withResultTypeName(QName value) { setResultTypeName(value); return this; } 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 Combine that = ((Combine) object); { 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, (this.source!= null), (that.source!= null))) { return false; } } { Expression lhsSeparator; lhsSeparator = this.getSeparator(); Expression rhsSeparator; rhsSeparator = that.getSeparator(); if (!strategy.equals(LocatorUtils.property(thisLocator, "separator", lhsSeparator), LocatorUtils.property(thatLocator, "separator", rhsSeparator), lhsSeparator, rhsSeparator, (this.separator!= null), (that.separator!= null))) { return false; } } return true; } public boolean equals(Object object) { final EqualsStrategy2 strategy = JAXBEqualsStrategy.INSTANCE2; return equals(null, null, object, strategy); } public int hashCode(ObjectLocator locator, HashCodeStrategy2 strategy) { int currentHashCode = super.hashCode(locator, strategy); { Expression theSource; theSource = this.getSource(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "source", theSource), currentHashCode, theSource, (this.source!= null)); } { Expression theSeparator; theSeparator = this.getSeparator(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "separator", theSeparator), currentHashCode, theSeparator, (this.separator!= null)); } return currentHashCode; } public int hashCode() { final HashCodeStrategy2 strategy = JAXBHashCodeStrategy.INSTANCE2; return this.hashCode(null, strategy); } public String toString() { final ToStringStrategy2 strategy = JAXBToStringStrategy.INSTANCE2; final StringBuilder buffer = new StringBuilder(); append(null, buffer, strategy); return buffer.toString(); } 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; } public StringBuilder appendFields(ObjectLocator locator, StringBuilder buffer, ToStringStrategy2 strategy) { super.appendFields(locator, buffer, strategy); { Expression theSource; theSource = this.getSource(); strategy.appendField(locator, this, "source", buffer, theSource, (this.source!= null)); } { Expression theSeparator; theSeparator = this.getSeparator(); strategy.appendField(locator, this, "separator", buffer, theSeparator, (this.separator!= null)); } return buffer; } }