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.v23.segment;
035
036// import ca.uhn.hl7v2.model.v23.group.*;
037import ca.uhn.hl7v2.model.v23.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/**
049 *<p>Represents an HL7 OM3 message segment (Categorical test/observation). 
050 * This segment has the following fields:</p>
051 * <ul>
052     * <li>OM3-1: Sequence Number - Test/ Observation Master File (NM) <b>optional </b>
053     * <li>OM3-2: Preferred Coding System (CE) <b>optional </b>
054     * <li>OM3-3: Valid Coded "Answers" (CE) <b>optional </b>
055     * <li>OM3-4: Normal Text/Codes for Categorical Observations (CE) <b>optional repeating</b>
056     * <li>OM3-5: Abnormal Text/Codes for Categorical Observations (CE) <b>optional </b>
057     * <li>OM3-6: Critical Text Codes for Categorical Observations (CE) <b>optional </b>
058     * <li>OM3-7: Value Type (ID) <b> </b>
059 * </ul>
060 */
061@SuppressWarnings("unused")
062public class OM3 extends AbstractSegment {
063
064    /** 
065     * Creates a new OM3 segment
066     */
067    public OM3(Group parent, ModelClassFactory factory) {
068       super(parent, factory);
069       init(factory);
070    }
071
072    private void init(ModelClassFactory factory) {
073       try {
074                                  this.add(NM.class, false, 1, 4, new Object[]{ getMessage() }, "Sequence Number - Test/ Observation Master File");
075                                  this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Preferred Coding System");
076                                  this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Valid Coded \"Answers\"");
077                                  this.add(CE.class, false, 0, 200, new Object[]{ getMessage() }, "Normal Text/Codes for Categorical Observations");
078                                  this.add(CE.class, false, 1, 200, new Object[]{ getMessage() }, "Abnormal Text/Codes for Categorical Observations");
079                                  this.add(CE.class, false, 1, 200, new Object[]{ getMessage() }, "Critical Text Codes for Categorical Observations");
080                                              this.add(ID.class, true, 1, 2, new Object[]{ getMessage(), new Integer(125) }, "Value Type");
081       } catch(HL7Exception e) {
082          log.error("Unexpected error creating OM3 - this is probably a bug in the source code generator.", e);
083       }
084    }
085
086
087
088    /**
089     * Returns
090     * OM3-1: "Sequence Number - Test/ Observation Master File" - creates it if necessary
091     */
092    public NM getSequenceNumberTestObservationMasterFile() { 
093                NM retVal = this.getTypedField(1, 0);
094                return retVal;
095    }
096    
097    /**
098     * Returns
099     * OM3-1: "Sequence Number - Test/ Observation Master File" - creates it if necessary
100     */
101    public NM getOm31_SequenceNumberTestObservationMasterFile() { 
102                NM retVal = this.getTypedField(1, 0);
103                return retVal;
104    }
105
106
107
108    /**
109     * Returns
110     * OM3-2: "Preferred Coding System" - creates it if necessary
111     */
112    public CE getPreferredCodingSystem() { 
113                CE retVal = this.getTypedField(2, 0);
114                return retVal;
115    }
116    
117    /**
118     * Returns
119     * OM3-2: "Preferred Coding System" - creates it if necessary
120     */
121    public CE getOm32_PreferredCodingSystem() { 
122                CE retVal = this.getTypedField(2, 0);
123                return retVal;
124    }
125
126
127
128    /**
129     * Returns
130     * OM3-3: "Valid Coded "Answers"" - creates it if necessary
131     */
132    public CE getValidCodedAnswers() { 
133                CE retVal = this.getTypedField(3, 0);
134                return retVal;
135    }
136    
137    /**
138     * Returns
139     * OM3-3: "Valid Coded "Answers"" - creates it if necessary
140     */
141    public CE getOm33_ValidCodedAnswers() { 
142                CE retVal = this.getTypedField(3, 0);
143                return retVal;
144    }
145
146
147    /**
148     * Returns all repetitions of Normal Text/Codes for Categorical Observations (OM3-4).
149     */
150    public CE[] getNormalTextCodesForCategoricalObservations() {
151        CE[] retVal = this.getTypedField(4, new CE[0]);
152        return retVal;
153    }
154
155
156    /**
157     * Returns all repetitions of Normal Text/Codes for Categorical Observations (OM3-4).
158     */
159    public CE[] getOm34_NormalTextCodesForCategoricalObservations() {
160        CE[] retVal = this.getTypedField(4, new CE[0]);
161        return retVal;
162    }
163
164
165    /**
166     * Returns a count of the current number of repetitions of Normal Text/Codes for Categorical Observations (OM3-4).
167     * This method does not create a repetition, so if no repetitions have currently been defined or accessed,
168     * it will return zero.
169     */
170    public int getNormalTextCodesForCategoricalObservationsReps() {
171        return this.getReps(4);
172    }
173
174
175    /**
176     * Returns a specific repetition of
177     * OM3-4: "Normal Text/Codes for Categorical Observations" - creates it if necessary
178     *
179     * @param rep The repetition index (0-indexed)
180     */
181    public CE getNormalTextCodesForCategoricalObservations(int rep) { 
182                CE retVal = this.getTypedField(4, rep);
183                return retVal;
184    }
185
186    /**
187     * Returns a specific repetition of
188     * OM3-4: "Normal Text/Codes for Categorical Observations" - creates it if necessary
189     *
190     * @param rep The repetition index (0-indexed)
191     */
192    public CE getOm34_NormalTextCodesForCategoricalObservations(int rep) { 
193                CE retVal = this.getTypedField(4, rep);
194                return retVal;
195    }
196
197    /**
198     * Returns a count of the current number of repetitions of Normal Text/Codes for Categorical Observations (OM3-4).
199     * This method does not create a repetition, so if no repetitions have currently been defined or accessed,
200     * it will return zero.
201     */
202    public int getOm34_NormalTextCodesForCategoricalObservationsReps() {
203        return this.getReps(4);
204    }
205
206
207    /**
208     * Inserts a repetition of
209     * OM3-4: "Normal Text/Codes for Categorical Observations" at a specific index
210     *
211     * @param rep The repetition index (0-indexed)
212     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
213     */
214    public CE insertNormalTextCodesForCategoricalObservations(int rep) throws HL7Exception { 
215        return (CE) super.insertRepetition(4, rep);
216    }
217
218
219    /**
220     * Inserts a repetition of
221     * OM3-4: "Normal Text/Codes for Categorical Observations" at a specific index
222     *
223     * @param rep The repetition index (0-indexed)
224     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
225     */
226    public CE insertOm34_NormalTextCodesForCategoricalObservations(int rep) throws HL7Exception { 
227        return (CE) super.insertRepetition(4, rep);
228    }
229
230
231    /**
232     * Removes a repetition of
233     * OM3-4: "Normal Text/Codes for Categorical Observations" at a specific index
234     *
235     * @param rep The repetition index (0-indexed)
236     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
237     */
238    public CE removeNormalTextCodesForCategoricalObservations(int rep) throws HL7Exception { 
239        return (CE) super.removeRepetition(4, rep);
240    }
241
242
243    /**
244     * Removes a repetition of
245     * OM3-4: "Normal Text/Codes for Categorical Observations" at a specific index
246     *
247     * @param rep The repetition index (0-indexed)
248     * @throws HL7Exception If the rep is invalid (below 0, or too high for the allowable repetitions)
249     */
250    public CE removeOm34_NormalTextCodesForCategoricalObservations(int rep) throws HL7Exception { 
251        return (CE) super.removeRepetition(4, rep);
252    }
253
254
255
256
257    /**
258     * Returns
259     * OM3-5: "Abnormal Text/Codes for Categorical Observations" - creates it if necessary
260     */
261    public CE getAbnormalTextCodesForCategoricalObservations() { 
262                CE retVal = this.getTypedField(5, 0);
263                return retVal;
264    }
265    
266    /**
267     * Returns
268     * OM3-5: "Abnormal Text/Codes for Categorical Observations" - creates it if necessary
269     */
270    public CE getOm35_AbnormalTextCodesForCategoricalObservations() { 
271                CE retVal = this.getTypedField(5, 0);
272                return retVal;
273    }
274
275
276
277    /**
278     * Returns
279     * OM3-6: "Critical Text Codes for Categorical Observations" - creates it if necessary
280     */
281    public CE getCriticalTextCodesForCategoricalObservations() { 
282                CE retVal = this.getTypedField(6, 0);
283                return retVal;
284    }
285    
286    /**
287     * Returns
288     * OM3-6: "Critical Text Codes for Categorical Observations" - creates it if necessary
289     */
290    public CE getOm36_CriticalTextCodesForCategoricalObservations() { 
291                CE retVal = this.getTypedField(6, 0);
292                return retVal;
293    }
294
295
296
297    /**
298     * Returns
299     * OM3-7: "Value Type" - creates it if necessary
300     */
301    public ID getValueType() { 
302                ID retVal = this.getTypedField(7, 0);
303                return retVal;
304    }
305    
306    /**
307     * Returns
308     * OM3-7: "Value Type" - creates it if necessary
309     */
310    public ID getOm37_ValueType() { 
311                ID retVal = this.getTypedField(7, 0);
312                return retVal;
313    }
314
315
316
317
318
319    /** {@inheritDoc} */   
320    protected Type createNewTypeWithoutReflection(int field) {
321       switch (field) {
322          case 0: return new NM(getMessage());
323          case 1: return new CE(getMessage());
324          case 2: return new CE(getMessage());
325          case 3: return new CE(getMessage());
326          case 4: return new CE(getMessage());
327          case 5: return new CE(getMessage());
328          case 6: return new ID(getMessage(), new Integer( 125 ));
329          default: return null;
330       }
331   }
332
333
334}
335