/*
* This class is an auto-generated source file for a HAPI
* HL7 v2.x standard structure class.
*
* For more information, visit: http://hl7api.sourceforge.net/
*
* The contents of this file are subject to the Mozilla Public License Version 1.1
* (the "License"); you may not use this file except in compliance with the License.
* You may obtain a copy of the License at http://www.mozilla.org/MPL/
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the
* specific language governing rights and limitations under the License.
*
* The Original Code is "[file_name]". Description:
* "[one_line_description]"
*
* The Initial Developer of the Original Code is University Health Network. Copyright (C)
* 2002. All Rights Reserved.
*
* Contributor(s): ______________________________________.
*
* Alternatively, the contents of this file may be used under the terms of the
* GNU General Public License (the "GPL"), in which case the provisions of the GPL are
* applicable instead of those above. If you wish to allow use of your version of this
* file only under the terms of the GPL and not to allow others to use your version
* of this file under the MPL, indicate your decision by deleting the provisions above
* and replace them with the notice and other provisions required by the GPL License.
* If you do not delete the provisions above, a recipient may use your version of
* this file under either the MPL or the GPL.
*
*/
package ca.uhn.hl7v2.model.v231.message;
import ca.uhn.hl7v2.model.v231.group.*;
import ca.uhn.hl7v2.model.v231.segment.*;
import java.util.List;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import ca.uhn.hl7v2.HL7Exception;
import ca.uhn.hl7v2.parser.ModelClassFactory;
import ca.uhn.hl7v2.parser.DefaultModelClassFactory;
import ca.uhn.hl7v2.model.AbstractMessage;
/**
* <p>Represents a RQC_I05 message structure (see chapter ?). This structure contains the
* following elements: </p>
* <ul>
* <li>1: MSH (MSH - message header segment) <b> </b></li>
* <li>2: QRD (QRD - original-style query definition segment) <b> </b></li>
* <li>3: QRF (QRF - original style query filter segment) <b>optional </b></li>
* <li>4: RQC_I05_PRDCTD (a Group object) <b> repeating</b></li>
* <li>5: PID (PID - patient identification segment) <b> </b></li>
* <li>6: NK1 (NK1 - next of kin / associated parties segment-) <b>optional repeating</b></li>
* <li>7: GT1 (GT1 - guarantor segment) <b>optional repeating</b></li>
* <li>8: NTE (NTE - notes and comments segment) <b>optional repeating</b></li>
* </ul>
*/
public class RQC_I05 extends AbstractMessage {
/**
* Creates a new RQC_I05 message with DefaultModelClassFactory.
*/
public RQC_I05() {
this(new DefaultModelClassFactory());
}
/**
* Creates a new RQC_I05 message with custom ModelClassFactory.
*/
public RQC_I05(ModelClassFactory factory) {
super(factory);
init(factory);
}
private void init(ModelClassFactory factory) {
try {
this.add(MSH.class, true, false);
this.add(QRD.class, true, false);
this.add(QRF.class, false, false);
this.add(RQC_I05_PRDCTD.class, true, true);
this.add(PID.class, true, false);
this.add(NK1.class, false, true);
this.add(GT1.class, false, true);
this.add(NTE.class, false, true);
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error creating RQC_I05 - this is probably a bug in the source code generator.", e);
}
}
/**
* Returns "2.3.1"
*/
public String getVersion() {
return "2.3.1";
}
/**
* Returns
* MSH (MSH - message header segment) - creates it if necessary
*/
public MSH getMSH() {
MSH ret = null;
try {
ret = (MSH)this.get("MSH");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns
* QRD (QRD - original-style query definition segment) - creates it if necessary
*/
public QRD getQRD() {
QRD ret = null;
try {
ret = (QRD)this.get("QRD");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns
* QRF (QRF - original style query filter segment) - creates it if necessary
*/
public QRF getQRF() {
QRF ret = null;
try {
ret = (QRF)this.get("QRF");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns
* the first repetition of
* PRDCTD (a Group object) - creates it if necessary
*/
public RQC_I05_PRDCTD getPRDCTD() {
RQC_I05_PRDCTD ret = null;
try {
ret = (RQC_I05_PRDCTD)this.get("PRDCTD");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns a specific repetition of
* PRDCTD (a Group object) - creates it if necessary
*
* @param rep The repetition index (0-indexed, i.e. the first repetition is at index 0)
* @throws HL7Exception if the repetition requested is more than one
* greater than the number of existing repetitions.
*/
public RQC_I05_PRDCTD getPRDCTD(int rep) {
RQC_I05_PRDCTD ret = null;
try {
ret = (RQC_I05_PRDCTD)this.get("PRDCTD", rep);
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns the number of existing repetitions of PRDCTD
*/
public int getPRDCTDReps() {
int reps = -1;
try {
reps = this.getAll("PRDCTD").length;
} catch (HL7Exception e) {
String message = "Unexpected error accessing data - this is probably a bug in the source code generator.";
LoggerFactory.getLogger(getClass()).error(message, e);
throw new RuntimeException(message);
}
return reps;
}
/**
* <p>
* Returns a non-modifiable List containing all current existing repetitions of PRDCTD.
* <p>
* <p>
* Note that unlike {@link #getPRDCTD()}, this method will not create any reps
* if none are already present, so an empty list may be returned.
* </p>
*/
public List<RQC_I05_PRDCTD> getPRDCTDAll() throws HL7Exception {
return this.getAllAsList("PRDCTD", RQC_I05_PRDCTD.class);
}
/**
* Inserts a specific repetition of PRDCTD (a Group object)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public void insertPRDCTD(RQC_I05_PRDCTD structure, int rep) throws HL7Exception {
super.insertRepetition( "PRDCTD", structure, rep);
}
/**
* Inserts a specific repetition of PRDCTD (a Group object)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public RQC_I05_PRDCTD insertPRDCTD(int rep) throws HL7Exception {
return (RQC_I05_PRDCTD)super.insertRepetition("PRDCTD", rep);
}
/**
* Removes a specific repetition of PRDCTD (a Group object)
* @see AbstractGroup#removeRepetition(String, int)
*/
public RQC_I05_PRDCTD removePRDCTD(int rep) throws HL7Exception {
return (RQC_I05_PRDCTD)super.removeRepetition("PRDCTD", rep);
}
/**
* Returns
* PID (PID - patient identification segment) - creates it if necessary
*/
public PID getPID() {
PID ret = null;
try {
ret = (PID)this.get("PID");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns
* the first repetition of
* NK1 (NK1 - next of kin / associated parties segment-) - creates it if necessary
*/
public NK1 getNK1() {
NK1 ret = null;
try {
ret = (NK1)this.get("NK1");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns a specific repetition of
* NK1 (NK1 - next of kin / associated parties segment-) - creates it if necessary
*
* @param rep The repetition index (0-indexed, i.e. the first repetition is at index 0)
* @throws HL7Exception if the repetition requested is more than one
* greater than the number of existing repetitions.
*/
public NK1 getNK1(int rep) {
NK1 ret = null;
try {
ret = (NK1)this.get("NK1", rep);
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns the number of existing repetitions of NK1
*/
public int getNK1Reps() {
int reps = -1;
try {
reps = this.getAll("NK1").length;
} catch (HL7Exception e) {
String message = "Unexpected error accessing data - this is probably a bug in the source code generator.";
LoggerFactory.getLogger(getClass()).error(message, e);
throw new RuntimeException(message);
}
return reps;
}
/**
* <p>
* Returns a non-modifiable List containing all current existing repetitions of NK1.
* <p>
* <p>
* Note that unlike {@link #getNK1()}, this method will not create any reps
* if none are already present, so an empty list may be returned.
* </p>
*/
public List<NK1> getNK1All() throws HL7Exception {
return this.getAllAsList("NK1", NK1.class);
}
/**
* Inserts a specific repetition of NK1 (NK1 - next of kin / associated parties segment-)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public void insertNK1(NK1 structure, int rep) throws HL7Exception {
super.insertRepetition( "NK1", structure, rep);
}
/**
* Inserts a specific repetition of NK1 (NK1 - next of kin / associated parties segment-)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public NK1 insertNK1(int rep) throws HL7Exception {
return (NK1)super.insertRepetition("NK1", rep);
}
/**
* Removes a specific repetition of NK1 (NK1 - next of kin / associated parties segment-)
* @see AbstractGroup#removeRepetition(String, int)
*/
public NK1 removeNK1(int rep) throws HL7Exception {
return (NK1)super.removeRepetition("NK1", rep);
}
/**
* Returns
* the first repetition of
* GT1 (GT1 - guarantor segment) - creates it if necessary
*/
public GT1 getGT1() {
GT1 ret = null;
try {
ret = (GT1)this.get("GT1");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns a specific repetition of
* GT1 (GT1 - guarantor segment) - creates it if necessary
*
* @param rep The repetition index (0-indexed, i.e. the first repetition is at index 0)
* @throws HL7Exception if the repetition requested is more than one
* greater than the number of existing repetitions.
*/
public GT1 getGT1(int rep) {
GT1 ret = null;
try {
ret = (GT1)this.get("GT1", rep);
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns the number of existing repetitions of GT1
*/
public int getGT1Reps() {
int reps = -1;
try {
reps = this.getAll("GT1").length;
} catch (HL7Exception e) {
String message = "Unexpected error accessing data - this is probably a bug in the source code generator.";
LoggerFactory.getLogger(getClass()).error(message, e);
throw new RuntimeException(message);
}
return reps;
}
/**
* <p>
* Returns a non-modifiable List containing all current existing repetitions of GT1.
* <p>
* <p>
* Note that unlike {@link #getGT1()}, this method will not create any reps
* if none are already present, so an empty list may be returned.
* </p>
*/
public List<GT1> getGT1All() throws HL7Exception {
return this.getAllAsList("GT1", GT1.class);
}
/**
* Inserts a specific repetition of GT1 (GT1 - guarantor segment)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public void insertGT1(GT1 structure, int rep) throws HL7Exception {
super.insertRepetition( "GT1", structure, rep);
}
/**
* Inserts a specific repetition of GT1 (GT1 - guarantor segment)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public GT1 insertGT1(int rep) throws HL7Exception {
return (GT1)super.insertRepetition("GT1", rep);
}
/**
* Removes a specific repetition of GT1 (GT1 - guarantor segment)
* @see AbstractGroup#removeRepetition(String, int)
*/
public GT1 removeGT1(int rep) throws HL7Exception {
return (GT1)super.removeRepetition("GT1", rep);
}
/**
* Returns
* the first repetition of
* NTE (NTE - notes and comments segment) - creates it if necessary
*/
public NTE getNTE() {
NTE ret = null;
try {
ret = (NTE)this.get("NTE");
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns a specific repetition of
* NTE (NTE - notes and comments segment) - creates it if necessary
*
* @param rep The repetition index (0-indexed, i.e. the first repetition is at index 0)
* @throws HL7Exception if the repetition requested is more than one
* greater than the number of existing repetitions.
*/
public NTE getNTE(int rep) {
NTE ret = null;
try {
ret = (NTE)this.get("NTE", rep);
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error accessing data - this is probably a bug in the source code generator.", e);
throw new RuntimeException(e);
}
return ret;
}
/**
* Returns the number of existing repetitions of NTE
*/
public int getNTEReps() {
int reps = -1;
try {
reps = this.getAll("NTE").length;
} catch (HL7Exception e) {
String message = "Unexpected error accessing data - this is probably a bug in the source code generator.";
LoggerFactory.getLogger(getClass()).error(message, e);
throw new RuntimeException(message);
}
return reps;
}
/**
* <p>
* Returns a non-modifiable List containing all current existing repetitions of NTE.
* <p>
* <p>
* Note that unlike {@link #getNTE()}, this method will not create any reps
* if none are already present, so an empty list may be returned.
* </p>
*/
public List<NTE> getNTEAll() throws HL7Exception {
return this.getAllAsList("NTE", NTE.class);
}
/**
* Inserts a specific repetition of NTE (NTE - notes and comments segment)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public void insertNTE(NTE structure, int rep) throws HL7Exception {
super.insertRepetition( "NTE", structure, rep);
}
/**
* Inserts a specific repetition of NTE (NTE - notes and comments segment)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public NTE insertNTE(int rep) throws HL7Exception {
return (NTE)super.insertRepetition("NTE", rep);
}
/**
* Removes a specific repetition of NTE (NTE - notes and comments segment)
* @see AbstractGroup#removeRepetition(String, int)
*/
public NTE removeNTE(int rep) throws HL7Exception {
return (NTE)super.removeRepetition("NTE", rep);
}
}