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.v24.segment;
035
036// import ca.uhn.hl7v2.model.v24.group.*;
037import ca.uhn.hl7v2.model.v24.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 (ELD) <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(ELD.class, true, 0, 80, new Object[]{ getMessage() }, "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 ELD[] getErrorCodeAndLocation() {
078        ELD[] retVal = this.getTypedField(1, new ELD[0]);
079        return retVal;
080    }
081
082
083    /**
084     * Returns all repetitions of Error Code and Location (ERR-1).
085     */
086    public ELD[] getErr1_ErrorCodeAndLocation() {
087        ELD[] retVal = this.getTypedField(1, new ELD[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 ELD getErrorCodeAndLocation(int rep) { 
109                ELD 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 ELD getErr1_ErrorCodeAndLocation(int rep) { 
120                ELD 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 ELD insertErrorCodeAndLocation(int rep) throws HL7Exception { 
142        return (ELD) 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 ELD insertErr1_ErrorCodeAndLocation(int rep) throws HL7Exception { 
154        return (ELD) 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 ELD removeErrorCodeAndLocation(int rep) throws HL7Exception { 
166        return (ELD) 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 ELD removeErr1_ErrorCodeAndLocation(int rep) throws HL7Exception { 
178        return (ELD) 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 ELD(getMessage());
190          default: return null;
191       }
192   }
193
194
195}
196