View Javadoc
1   /*
2    * This class is an auto-generated source file for a HAPI
3    * HL7 v2.x standard structure class.
4    *
5    * For more information, visit: http://hl7api.sourceforge.net/
6    * 
7    * The contents of this file are subject to the Mozilla Public License Version 1.1 
8    * (the "License"); you may not use this file except in compliance with the License. 
9    * You may obtain a copy of the License at http://www.mozilla.org/MPL/ 
10   * Software distributed under the License is distributed on an "AS IS" basis, 
11   * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the 
12   * specific language governing rights and limitations under the License. 
13   * 
14   * The Original Code is "[file_name]".  Description: 
15   * "[one_line_description]" 
16   * 
17   * The Initial Developer of the Original Code is University Health Network. Copyright (C) 
18   * 2012.  All Rights Reserved. 
19   * 
20   * Contributor(s): ______________________________________. 
21   * 
22   * Alternatively, the contents of this file may be used under the terms of the 
23   * GNU General Public License (the  "GPL"), in which case the provisions of the GPL are 
24   * applicable instead of those above.  If you wish to allow use of your version of this 
25   * file only under the terms of the GPL and not to allow others to use your version 
26   * of this file under the MPL, indicate your decision by deleting  the provisions above 
27   * and replace  them with the notice and other provisions required by the GPL License.  
28   * If you do not delete the provisions above, a recipient may use your version of 
29   * this file under either the MPL or the GPL. 
30   * 
31   */
32  
33  
34  package ca.uhn.hl7v2.model.v231.segment;
35  
36  // import ca.uhn.hl7v2.model.v231.group.*;
37  import ca.uhn.hl7v2.model.v231.datatype.*;
38  import ca.uhn.hl7v2.HL7Exception;
39  import ca.uhn.hl7v2.parser.ModelClassFactory;
40  import ca.uhn.hl7v2.parser.DefaultModelClassFactory;
41  import ca.uhn.hl7v2.model.AbstractMessage;
42  import ca.uhn.hl7v2.model.Group;
43  import ca.uhn.hl7v2.model.Type;
44  import ca.uhn.hl7v2.model.AbstractSegment;
45  import ca.uhn.hl7v2.model.Varies;
46  
47  
48  /**
49   *<p>Represents an HL7 OM3 message segment (OM3 - categorical test/observation segment). 
50   * This segment has the following fields:</p>
51   * <ul>
52       * <li>OM3-1: Sequence Number - Test/Observation Master File (NM) <b>optional </b>
53       * <li>OM3-2: Preferred Coding System (CE) <b>optional </b>
54       * <li>OM3-3: Valid Coded “Answers” (CE) <b>optional </b>
55       * <li>OM3-4: Normal Text/Codes for Categorical Observations (CE) <b>optional repeating</b>
56       * <li>OM3-5: Abnormal Text/Codes for Categorical Observations (CE) <b>optional </b>
57       * <li>OM3-6: Critical Text Codes for Categorical Observations (CE) <b>optional </b>
58       * <li>OM3-7: Value Type (ID) <b>optional </b>
59   * </ul>
60   */
61  @SuppressWarnings("unused")
62  public class OM3 extends AbstractSegment {
63  
64      /** 
65       * Creates a new OM3 segment
66       */
67      public OM3(Group parent, ModelClassFactory factory) {
68         super(parent, factory);
69         init(factory);
70      }
71  
72      private void init(ModelClassFactory factory) {
73         try {
74                                    this.add(NM.class, false, 1, 4, new Object[]{ getMessage() }, "Sequence Number - Test/Observation Master File");
75                                    this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Preferred Coding System");
76                                    this.add(CE.class, false, 1, 60, new Object[]{ getMessage() }, "Valid Coded “Answers”");
77                                    this.add(CE.class, false, 0, 200, new Object[]{ getMessage() }, "Normal Text/Codes for Categorical Observations");
78                                    this.add(CE.class, false, 1, 200, new Object[]{ getMessage() }, "Abnormal Text/Codes for Categorical Observations");
79                                    this.add(CE.class, false, 1, 200, new Object[]{ getMessage() }, "Critical Text Codes for Categorical Observations");
80                                                this.add(ID.class, false, 1, 3, new Object[]{ getMessage(), new Integer(125) }, "Value Type");
81         } catch(HL7Exception e) {
82            log.error("Unexpected error creating OM3 - this is probably a bug in the source code generator.", e);
83         }
84      }
85  
86  
87  
88      /**
89       * Returns
90       * OM3-1: "Sequence Number - Test/Observation Master File" - creates it if necessary
91       */
92      public NM getSequenceNumberTestObservationMasterFile() { 
93  		NM retVal = this.getTypedField(1, 0);
94  		return retVal;
95      }
96      
97      /**
98       * Returns
99       * 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