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

org.hl7.elm.r1.Instance 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 JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.4.0-b180830.0438 
// See https://javaee.github.io/jaxb-v2/ 
// Any modifications to this file will be lost upon recompilation of the source schema. 
// Generated on: 2023.03.28 at 04:17:15 PM MDT 
//


package org.hl7.elm.r1;

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.XmlType;
import javax.xml.namespace.QName;
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 Instance expression allows class instances of any type to be built up as an expression. The classType attribute specifies the type of the class instance being built, and the list of instance elements specify the values for the elements of the class instance. Note that the value of an element may be any expression, including another Instance.
 * 
 * 

Java class for Instance complex type. * *

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

 * <complexType name="Instance">
 *   <complexContent>
 *     <extension base="{urn:hl7-org:elm:r1}Expression">
 *       <sequence>
 *         <element name="element" type="{urn:hl7-org:elm:r1}InstanceElement" maxOccurs="unbounded" minOccurs="0"/>
 *       </sequence>
 *       <attribute name="classType" use="required" type="{http://www.w3.org/2001/XMLSchema}QName" />
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "Instance", namespace = "urn:hl7-org:elm:r1", propOrder = { "element" }) public class Instance extends Expression implements Equals2, HashCode2, ToString2 { @XmlElement(namespace = "urn:hl7-org:elm:r1") protected List element; @XmlAttribute(name = "classType", required = true) protected QName classType; /** * Gets the value of the element 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 element property. * *

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

     *    getElement().add(newItem);
     * 
* * *

* Objects of the following type(s) are allowed in the list * {@link InstanceElement } * * */ public List getElement() { if (element == null) { element = new ArrayList(); } return this.element; } /** * Gets the value of the classType property. * * @return * possible object is * {@link QName } * */ public QName getClassType() { return classType; } /** * Sets the value of the classType property. * * @param value * allowed object is * {@link QName } * */ public void setClassType(QName value) { this.classType = value; } public Instance withElement(InstanceElement... values) { if (values!= null) { for (InstanceElement value: values) { getElement().add(value); } } return this; } public Instance withElement(Collection values) { if (values!= null) { getElement().addAll(values); } return this; } public Instance withClassType(QName value) { setClassType(value); return this; } @Override public Instance withAnnotation(CqlToElmBase... values) { if (values!= null) { for (CqlToElmBase value: values) { getAnnotation().add(value); } } return this; } @Override public Instance withAnnotation(Collection values) { if (values!= null) { getAnnotation().addAll(values); } return this; } @Override public Instance withResultTypeSpecifier(TypeSpecifier value) { setResultTypeSpecifier(value); return this; } @Override public Instance withLocalId(String value) { setLocalId(value); return this; } @Override public Instance withLocator(String value) { setLocator(value); return this; } @Override public Instance 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 Instance that = ((Instance) object); { List lhsElement; lhsElement = (((this.element!= null)&&(!this.element.isEmpty()))?this.getElement():null); List rhsElement; rhsElement = (((that.element!= null)&&(!that.element.isEmpty()))?that.getElement():null); if (!strategy.equals(LocatorUtils.property(thisLocator, "element", lhsElement), LocatorUtils.property(thatLocator, "element", rhsElement), lhsElement, rhsElement, ((this.element!= null)&&(!this.element.isEmpty())), ((that.element!= null)&&(!that.element.isEmpty())))) { return false; } } { QName lhsClassType; lhsClassType = this.getClassType(); QName rhsClassType; rhsClassType = that.getClassType(); if (!strategy.equals(LocatorUtils.property(thisLocator, "classType", lhsClassType), LocatorUtils.property(thatLocator, "classType", rhsClassType), lhsClassType, rhsClassType, (this.classType!= null), (that.classType!= 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); { List theElement; theElement = (((this.element!= null)&&(!this.element.isEmpty()))?this.getElement():null); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "element", theElement), currentHashCode, theElement, ((this.element!= null)&&(!this.element.isEmpty()))); } { QName theClassType; theClassType = this.getClassType(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "classType", theClassType), currentHashCode, theClassType, (this.classType!= 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); { List theElement; theElement = (((this.element!= null)&&(!this.element.isEmpty()))?this.getElement():null); strategy.appendField(locator, this, "element", buffer, theElement, ((this.element!= null)&&(!this.element.isEmpty()))); } { QName theClassType; theClassType = this.getClassType(); strategy.appendField(locator, this, "classType", buffer, theClassType, (this.classType!= null)); } return buffer; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy