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.v26.segment;
035
036// import ca.uhn.hl7v2.model.v26.group.*;
037import ca.uhn.hl7v2.model.v26.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 FHS message segment (File Header). 
049 * This segment has the following fields:</p>
050 * <ul>
051     * <li>FHS-1: File Field Separator (ST) <b> </b>
052     * <li>FHS-2: File Encoding Characters (ST) <b> </b>
053     * <li>FHS-3: File Sending Application (HD) <b>optional </b>
054     * <li>FHS-4: File Sending Facility (HD) <b>optional </b>
055     * <li>FHS-5: File Receiving Application (HD) <b>optional </b>
056     * <li>FHS-6: File Receiving Facility (HD) <b>optional </b>
057     * <li>FHS-7: File Creation Date/Time (DTM) <b>optional </b>
058     * <li>FHS-8: File Security (ST) <b>optional </b>
059     * <li>FHS-9: File Name/ID (ST) <b>optional </b>
060     * <li>FHS-10: File Header Comment (ST) <b>optional </b>
061     * <li>FHS-11: File Control ID (ST) <b>optional </b>
062     * <li>FHS-12: Reference File Control ID (ST) <b>optional </b>
063     * <li>FHS-13: File Sending Network Address (HD) <b>optional </b>
064     * <li>FHS-14: File Receiving Network Address (HD) <b>optional </b>
065 * </ul>
066 */
067@SuppressWarnings("unused")
068public class FHS extends AbstractSegment {
069
070    /** 
071     * Creates a new FHS segment
072     */
073    public FHS(Group parent, ModelClassFactory factory) {
074       super(parent, factory);
075       init(factory);
076    }
077
078    private void init(ModelClassFactory factory) {
079       try {
080                                  this.add(ST.class, true, 1, 1, new Object[]{ getMessage() }, "File Field Separator");
081                                  this.add(ST.class, true, 1, 4, new Object[]{ getMessage() }, "File Encoding Characters");
082                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "File Sending Application");
083                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "File Sending Facility");
084                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "File Receiving Application");
085                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "File Receiving Facility");
086                                  this.add(DTM.class, false, 1, 24, new Object[]{ getMessage() }, "File Creation Date/Time");
087                                  this.add(ST.class, false, 1, 40, new Object[]{ getMessage() }, "File Security");
088                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "File Name/ID");
089                                  this.add(ST.class, false, 1, 80, new Object[]{ getMessage() }, "File Header Comment");
090                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "File Control ID");
091                                  this.add(ST.class, false, 1, 20, new Object[]{ getMessage() }, "Reference File Control ID");
092                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "File Sending Network Address");
093                                  this.add(HD.class, false, 1, 227, new Object[]{ getMessage() }, "File Receiving Network Address");
094       } catch(HL7Exception e) {
095          log.error("Unexpected error creating FHS - this is probably a bug in the source code generator.", e);
096       }
097    }
098
099
100
101    /**
102     * Returns
103     * FHS-1: "File Field Separator" - creates it if necessary
104     */
105    public ST getFileFieldSeparator() { 
106                ST retVal = this.getTypedField(1, 0);
107                return retVal;
108    }
109    
110    /**
111     * Returns
112     * FHS-1: "File Field Separator" - creates it if necessary
113     */
114    public ST getFhs1_FileFieldSeparator() { 
115                ST retVal = this.getTypedField(1, 0);
116                return retVal;
117    }
118
119
120
121    /**
122     * Returns
123     * FHS-2: "File Encoding Characters" - creates it if necessary
124     */
125    public ST getFileEncodingCharacters() { 
126                ST retVal = this.getTypedField(2, 0);
127                return retVal;
128    }
129    
130    /**
131     * Returns
132     * FHS-2: "File Encoding Characters" - creates it if necessary
133     */
134    public ST getFhs2_FileEncodingCharacters() { 
135                ST retVal = this.getTypedField(2, 0);
136                return retVal;
137    }
138
139
140
141    /**
142     * Returns
143     * FHS-3: "File Sending Application" - creates it if necessary
144     */
145    public HD getFileSendingApplication() { 
146                HD retVal = this.getTypedField(3, 0);
147                return retVal;
148    }
149    
150    /**
151     * Returns
152     * FHS-3: "File Sending Application" - creates it if necessary
153     */
154    public HD getFhs3_FileSendingApplication() { 
155                HD retVal = this.getTypedField(3, 0);
156                return retVal;
157    }
158
159
160
161    /**
162     * Returns
163     * FHS-4: "File Sending Facility" - creates it if necessary
164     */
165    public HD getFileSendingFacility() { 
166                HD retVal = this.getTypedField(4, 0);
167                return retVal;
168    }
169    
170    /**
171     * Returns
172     * FHS-4: "File Sending Facility" - creates it if necessary
173     */
174    public HD getFhs4_FileSendingFacility() { 
175                HD retVal = this.getTypedField(4, 0);
176                return retVal;
177    }
178
179
180
181    /**
182     * Returns
183     * FHS-5: "File Receiving Application" - creates it if necessary
184     */
185    public HD getFileReceivingApplication() { 
186                HD retVal = this.getTypedField(5, 0);
187                return retVal;
188    }
189    
190    /**
191     * Returns
192     * FHS-5: "File Receiving Application" - creates it if necessary
193     */
194    public HD getFhs5_FileReceivingApplication() { 
195                HD retVal = this.getTypedField(5, 0);
196                return retVal;
197    }
198
199
200
201    /**
202     * Returns
203     * FHS-6: "File Receiving Facility" - creates it if necessary
204     */
205    public HD getFileReceivingFacility() { 
206                HD retVal = this.getTypedField(6, 0);
207                return retVal;
208    }
209    
210    /**
211     * Returns
212     * FHS-6: "File Receiving Facility" - creates it if necessary
213     */
214    public HD getFhs6_FileReceivingFacility() { 
215                HD retVal = this.getTypedField(6, 0);
216                return retVal;
217    }
218
219
220
221    /**
222     * Returns
223     * FHS-7: "File Creation Date/Time" - creates it if necessary
224     */
225    public DTM getFileCreationDateTime() { 
226                DTM retVal = this.getTypedField(7, 0);
227                return retVal;
228    }
229    
230    /**
231     * Returns
232     * FHS-7: "File Creation Date/Time" - creates it if necessary
233     */
234    public DTM getFhs7_FileCreationDateTime() { 
235                DTM retVal = this.getTypedField(7, 0);
236                return retVal;
237    }
238
239
240
241    /**
242     * Returns
243     * FHS-8: "File Security" - creates it if necessary
244     */
245    public ST getFileSecurity() { 
246                ST retVal = this.getTypedField(8, 0);
247                return retVal;
248    }
249    
250    /**
251     * Returns
252     * FHS-8: "File Security" - creates it if necessary
253     */
254    public ST getFhs8_FileSecurity() { 
255                ST retVal = this.getTypedField(8, 0);
256                return retVal;
257    }
258
259
260
261    /**
262     * Returns
263     * FHS-9: "File Name/ID" - creates it if necessary
264     */
265    public ST getFileNameID() { 
266                ST retVal = this.getTypedField(9, 0);
267                return retVal;
268    }
269    
270    /**
271     * Returns
272     * FHS-9: "File Name/ID" - creates it if necessary
273     */
274    public ST getFhs9_FileNameID() { 
275                ST retVal = this.getTypedField(9, 0);
276                return retVal;
277    }
278
279
280
281    /**
282     * Returns
283     * FHS-10: "File Header Comment" - creates it if necessary
284     */
285    public ST getFileHeaderComment() { 
286                ST retVal = this.getTypedField(10, 0);
287                return retVal;
288    }
289    
290    /**
291     * Returns
292     * FHS-10: "File Header Comment" - creates it if necessary
293     */
294    public ST getFhs10_FileHeaderComment() { 
295                ST retVal = this.getTypedField(10, 0);
296                return retVal;
297    }
298
299
300
301    /**
302     * Returns
303     * FHS-11: "File Control ID" - creates it if necessary
304     */
305    public ST getFileControlID() { 
306                ST retVal = this.getTypedField(11, 0);
307                return retVal;
308    }
309    
310    /**
311     * Returns
312     * FHS-11: "File Control ID" - creates it if necessary
313     */
314    public ST getFhs11_FileControlID() { 
315                ST retVal = this.getTypedField(11, 0);
316                return retVal;
317    }
318
319
320
321    /**
322     * Returns
323     * FHS-12: "Reference File Control ID" - creates it if necessary
324     */
325    public ST getReferenceFileControlID() { 
326                ST retVal = this.getTypedField(12, 0);
327                return retVal;
328    }
329    
330    /**
331     * Returns
332     * FHS-12: "Reference File Control ID" - creates it if necessary
333     */
334    public ST getFhs12_ReferenceFileControlID() { 
335                ST retVal = this.getTypedField(12, 0);
336                return retVal;
337    }
338
339
340
341    /**
342     * Returns
343     * FHS-13: "File Sending Network Address" - creates it if necessary
344     */
345    public HD getFileSendingNetworkAddress() { 
346                HD retVal = this.getTypedField(13, 0);
347                return retVal;
348    }
349    
350    /**
351     * Returns
352     * FHS-13: "File Sending Network Address" - creates it if necessary
353     */
354    public HD getFhs13_FileSendingNetworkAddress() { 
355                HD retVal = this.getTypedField(13, 0);
356                return retVal;
357    }
358
359
360
361    /**
362     * Returns
363     * FHS-14: "File Receiving Network Address" - creates it if necessary
364     */
365    public HD getFileReceivingNetworkAddress() { 
366                HD retVal = this.getTypedField(14, 0);
367                return retVal;
368    }
369    
370    /**
371     * Returns
372     * FHS-14: "File Receiving Network Address" - creates it if necessary
373     */
374    public HD getFhs14_FileReceivingNetworkAddress() { 
375                HD retVal = this.getTypedField(14, 0);
376                return retVal;
377    }
378
379
380
381
382
383    /** {@inheritDoc} */   
384    protected Type createNewTypeWithoutReflection(int field) {
385       switch (field) {
386          case 0: return new ST(getMessage());
387          case 1: return new ST(getMessage());
388          case 2: return new HD(getMessage());
389          case 3: return new HD(getMessage());
390          case 4: return new HD(getMessage());
391          case 5: return new HD(getMessage());
392          case 6: return new DTM(getMessage());
393          case 7: return new ST(getMessage());
394          case 8: return new ST(getMessage());
395          case 9: return new ST(getMessage());
396          case 10: return new ST(getMessage());
397          case 11: return new ST(getMessage());
398          case 12: return new HD(getMessage());
399          case 13: return new HD(getMessage());
400          default: return null;
401       }
402   }
403
404
405}
406