001/*
002 * This class is an auto-generated source file for a HAPI
003 * HL7 v2.x standard structure class.
004 *
005 * For more information, visit: http://hl7api.sourceforge.net/
006 * 
007 * The contents of this file are subject to the Mozilla Public License Version 1.1 
008 * (the "License"); you may not use this file except in compliance with the License. 
009 * You may obtain a copy of the License at http://www.mozilla.org/MPL/ 
010 * Software distributed under the License is distributed on an "AS IS" basis, 
011 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the 
012 * specific language governing rights and limitations under the License. 
013 * 
014 * The Original Code is "[file_name]".  Description: 
015 * "[one_line_description]" 
016 * 
017 * The Initial Developer of the Original Code is University Health Network. Copyright (C) 
018 * 2012.  All Rights Reserved. 
019 * 
020 * Contributor(s): ______________________________________. 
021 * 
022 * Alternatively, the contents of this file may be used under the terms of the 
023 * GNU General Public License (the  "GPL"), in which case the provisions of the GPL are 
024 * applicable instead of those above.  If you wish to allow use of your version of this 
025 * file only under the terms of the GPL and not to allow others to use your version 
026 * of this file under the MPL, indicate your decision by deleting  the provisions above 
027 * and replace  them with the notice and other provisions required by the GPL License.  
028 * If you do not delete the provisions above, a recipient may use your version of 
029 * this file under either the MPL or the GPL. 
030 * 
031 */
032
033
034package ca.uhn.hl7v2.model.v21.segment;
035
036// import ca.uhn.hl7v2.model.v21.group.*;
037import ca.uhn.hl7v2.model.v21.datatype.*;
038import ca.uhn.hl7v2.HL7Exception;
039import ca.uhn.hl7v2.parser.ModelClassFactory;
040import ca.uhn.hl7v2.parser.DefaultModelClassFactory;
041import ca.uhn.hl7v2.model.AbstractMessage;
042import ca.uhn.hl7v2.model.Group;
043import ca.uhn.hl7v2.model.Type;
044import ca.uhn.hl7v2.model.AbstractSegment;
045import ca.uhn.hl7v2.model.Varies;
046
047/**
048 *<p>Represents an HL7 ERR message segment (ERROR). 
049 * This segment has the following fields:</p>
050 * <ul>
051     * <li>ERR-1: ERROR CODE AND LOCATION (ID) <b> repeating</b>
052 * </ul>
053 */
054@SuppressWarnings("unused")
055public class ERR extends AbstractSegment {
056
057    /** 
058     * Creates a new ERR segment
059     */
060    public ERR(Group parent, ModelClassFactory factory) {
061       super(parent, factory);
062       init(factory);
063    }
064
065    private void init(ModelClassFactory factory) {
066       try {
067                                              this.add(ID.class, true, 0, 80, new Object[]{ getMessage(), new Integer(60) }, "ERROR CODE AND LOCATION");
068       } catch(HL7Exception e) {
069          log.error("Unexpected error creating ERR - this is probably a bug in the source code generator.", e);
070       }
071    }
072
073
074    /**
075     * Returns all repetitions of ERROR CODE AND LOCATION (ERR-1).
076     */
077    public ID[] getERRORCODEANDLOCATION() {
078        ID[] retVal = this.getTypedField(1, new ID[0]);
079        return retVal;
080    }
081
082
083    /**
084     * Returns all repetitions of ERROR CODE AND LOCATION (ERR-1).
085     */
086    public ID[] getErr1_ERRORCODEANDLOCATION() {
087        ID[] retVal = this.getTypedField(1, new ID[0]);
088        return retVal;
089    }
090
091
092    /**
093     * Returns a count of the current number of repetitions of ERROR CODE AND LOCATION (ERR-1).
094     * This method does not create a repetition, so if no repetitions have currently been defined or accessed,
095     * it will return zero.
096     */
097    public int getERRORCODEANDLOCATIONReps() {
098        return this.getReps(1);
099    }
100
101
102    /**
103     * Returns a specific repetition of
104     * ERR-1: "ERROR CODE AND LOCATION" - creates it if necessary
105     *
106     * @param rep The repetition index (0-indexed)
107     */
108    public ID getERRORCODEANDLOCATION(int rep) { 
109                ID retVal = this.getTypedField(1, rep);
110                return retVal;
111    }
112
113    /**
114     * Returns a specific repetition of
115     * ERR-1: "ERROR CODE AND LOCATION" - creates it if necessary
116     *
117     * @param rep The repetition index (0-indexed)
118     */
119    public ID getErr1_ERRORCODEANDLOCATION(int rep) { 
120                ID retVal = this.getTypedField(1, rep);
121                return retVal;
122    }
123
124    /**
125     * Returns a count of the current number of repetitions of ERROR CODE AND LOCATION (ERR-1).
126     * This method does not create a repetition, so if no repetitions have currently been defined or accessed,
127     * it will return zero.
128     */
129    public int getErr1_ERRORCODEANDLOCATIONReps() {
130        return this.getReps(1);
131    }
132
133
134    /**
135     * Inserts a repetition of
136     * ERR-1: "ERROR CODE AND LOCATION" at a specific index
137     *
138     * @param rep The repetition index (0-indexed)
139     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
140     */
141    public ID insertERRORCODEANDLOCATION(int rep) throws HL7Exception { 
142        return (ID) super.insertRepetition(1, rep);
143    }
144
145
146    /**
147     * Inserts a repetition of
148     * ERR-1: "ERROR CODE AND LOCATION" at a specific index
149     *
150     * @param rep The repetition index (0-indexed)
151     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
152     */
153    public ID insertErr1_ERRORCODEANDLOCATION(int rep) throws HL7Exception { 
154        return (ID) super.insertRepetition(1, rep);
155    }
156
157
158    /**
159     * Removes a repetition of
160     * ERR-1: "ERROR CODE AND LOCATION" at a specific index
161     *
162     * @param rep The repetition index (0-indexed)
163     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
164     */
165    public ID removeERRORCODEANDLOCATION(int rep) throws HL7Exception { 
166        return (ID) super.removeRepetition(1, rep);
167    }
168
169
170    /**
171     * Removes a repetition of
172     * ERR-1: "ERROR CODE AND LOCATION" at a specific index
173     *
174     * @param rep The repetition index (0-indexed)
175     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
176     */
177    public ID removeErr1_ERRORCODEANDLOCATION(int rep) throws HL7Exception { 
178        return (ID) super.removeRepetition(1, rep);
179    }
180
181
182
183
184
185
186    /** {@inheritDoc} */   
187    protected Type createNewTypeWithoutReflection(int field) {
188       switch (field) {
189          case 0: return new ID(getMessage(), new Integer( 60 ));
190          default: return null;
191       }
192   }
193
194
195}
196