ca.uhn.hl7v2.model.v24.message.BAR_P05 Maven / Gradle / Ivy
/*
* 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.v24.message;
import ca.uhn.hl7v2.model.v24.group.*;
import ca.uhn.hl7v2.model.v24.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;
/**
* Represents a BAR_P05 message structure (see chapter 6). This structure contains the
* following elements:
*
* - 1: MSH (Message Header)
* - 2: EVN (Event Type)
* - 3: PID (Patient identification)
* - 4: PD1 (patient additional demographic) optional
* - 5: ROL (Role) optional repeating
* - 6: BAR_P05_VISIT (a Group object) repeating
*
*/
public class BAR_P05 extends AbstractMessage {
/**
* Creates a new BAR_P05 message with DefaultModelClassFactory.
*/
public BAR_P05() {
this(new DefaultModelClassFactory());
}
/**
* Creates a new BAR_P05 message with custom ModelClassFactory.
*/
public BAR_P05(ModelClassFactory factory) {
super(factory);
init(factory);
}
private void init(ModelClassFactory factory) {
try {
this.add(MSH.class, true, false);
this.add(EVN.class, true, false);
this.add(PID.class, true, false);
this.add(PD1.class, false, false);
this.add(ROL.class, false, true);
this.add(BAR_P05_VISIT.class, true, true);
} catch(HL7Exception e) {
LoggerFactory.getLogger(getClass()).error("Unexpected error creating BAR_P05 - this is probably a bug in the source code generator.", e);
}
}
/**
* Returns "2.4"
*/
public String getVersion() {
return "2.4";
}
/**
* Returns
* MSH (Message Header) - 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
* EVN (Event Type) - creates it if necessary
*/
public EVN getEVN() {
EVN ret = null;
try {
ret = (EVN)this.get("EVN");
} 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
* PID (Patient identification) - 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
* PD1 (patient additional demographic) - creates it if necessary
*/
public PD1 getPD1() {
PD1 ret = null;
try {
ret = (PD1)this.get("PD1");
} 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
* ROL (Role) - creates it if necessary
*/
public ROL getROL() {
ROL ret = null;
try {
ret = (ROL)this.get("ROL");
} 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
* ROL (Role) - 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 ROL getROL(int rep) {
ROL ret = null;
try {
ret = (ROL)this.get("ROL", 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 ROL
*/
public int getROLReps() {
int reps = -1;
try {
reps = this.getAll("ROL").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;
}
/**
*
* Returns a non-modifiable List containing all current existing repetitions of ROL.
*
*
* Note that unlike {@link #getROL()}, this method will not create any reps
* if none are already present, so an empty list may be returned.
*
*/
public List getROLAll() throws HL7Exception {
return this.getAllAsList("ROL", ROL.class);
}
/**
* Inserts a specific repetition of ROL (Role)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public void insertROL(ROL structure, int rep) throws HL7Exception {
super.insertRepetition( "ROL", structure, rep);
}
/**
* Inserts a specific repetition of ROL (Role)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public ROL insertROL(int rep) throws HL7Exception {
return (ROL)super.insertRepetition("ROL", rep);
}
/**
* Removes a specific repetition of ROL (Role)
* @see AbstractGroup#removeRepetition(String, int)
*/
public ROL removeROL(int rep) throws HL7Exception {
return (ROL)super.removeRepetition("ROL", rep);
}
/**
* Returns
* the first repetition of
* VISIT (a Group object) - creates it if necessary
*/
public BAR_P05_VISIT getVISIT() {
BAR_P05_VISIT ret = null;
try {
ret = (BAR_P05_VISIT)this.get("VISIT");
} 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
* VISIT (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 BAR_P05_VISIT getVISIT(int rep) {
BAR_P05_VISIT ret = null;
try {
ret = (BAR_P05_VISIT)this.get("VISIT", 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 VISIT
*/
public int getVISITReps() {
int reps = -1;
try {
reps = this.getAll("VISIT").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;
}
/**
*
* Returns a non-modifiable List containing all current existing repetitions of VISIT.
*
*
* Note that unlike {@link #getVISIT()}, this method will not create any reps
* if none are already present, so an empty list may be returned.
*
*/
public List getVISITAll() throws HL7Exception {
return this.getAllAsList("VISIT", BAR_P05_VISIT.class);
}
/**
* Inserts a specific repetition of VISIT (a Group object)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public void insertVISIT(BAR_P05_VISIT structure, int rep) throws HL7Exception {
super.insertRepetition( "VISIT", structure, rep);
}
/**
* Inserts a specific repetition of VISIT (a Group object)
* @see AbstractGroup#insertRepetition(Structure, int)
*/
public BAR_P05_VISIT insertVISIT(int rep) throws HL7Exception {
return (BAR_P05_VISIT)super.insertRepetition("VISIT", rep);
}
/**
* Removes a specific repetition of VISIT (a Group object)
* @see AbstractGroup#removeRepetition(String, int)
*/
public BAR_P05_VISIT removeVISIT(int rep) throws HL7Exception {
return (BAR_P05_VISIT)super.removeRepetition("VISIT", rep);
}
}