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.v22.segment;
035
036// import ca.uhn.hl7v2.model.v22.group.*;
037import ca.uhn.hl7v2.model.v22.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 NSC message segment (STATUS CHANGE). 
050 * This segment has the following fields:</p>
051 * <ul>
052     * <li>NSC-1: Network Change Type (ID) <b> </b>
053     * <li>NSC-2: Current CPU (ST) <b>optional </b>
054     * <li>NSC-3: Current Fileserver (ST) <b>optional </b>
055     * <li>NSC-4: Current Application (ST) <b>optional </b>
056     * <li>NSC-5: Current Facility (ST) <b>optional </b>
057     * <li>NSC-6: New CPU (ST) <b>optional </b>
058     * <li>NSC-7: New Fileserver (ST) <b>optional </b>
059     * <li>NSC-8: New Application (ST) <b>optional </b>
060     * <li>NSC-9: New Facility (ST) <b>optional </b>
061 * </ul>
062 */
063@SuppressWarnings("unused")
064public class NSC extends AbstractSegment {
065
066    /** 
067     * Creates a new NSC segment
068     */
069    public NSC(Group parent, ModelClassFactory factory) {
070       super(parent, factory);
071       init(factory);
072    }
073
074    private void init(ModelClassFactory factory) {
075       try {
076                                              this.add(ID.class, true, 1, 4, new Object[]{ getMessage(), new Integer(0) }, "Network Change Type");
077                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "Current CPU");
078                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "Current Fileserver");
079                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "Current Application");
080                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "Current Facility");
081                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "New CPU");
082                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "New Fileserver");
083                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "New Application");
084                                  this.add(ST.class, false, 1, 30, new Object[]{ getMessage() }, "New Facility");
085       } catch(HL7Exception e) {
086          log.error("Unexpected error creating NSC - this is probably a bug in the source code generator.", e);
087       }
088    }
089
090
091
092    /**
093     * Returns
094     * NSC-1: "Network Change Type" - creates it if necessary
095     */
096    public ID getNetworkChangeType() { 
097                ID retVal = this.getTypedField(1, 0);
098                return retVal;
099    }
100    
101    /**
102     * Returns
103     * NSC-1: "Network Change Type" - creates it if necessary
104     */
105    public ID getNsc1_NetworkChangeType() { 
106                ID retVal = this.getTypedField(1, 0);
107                return retVal;
108    }
109
110
111
112    /**
113     * Returns
114     * NSC-2: "Current CPU" - creates it if necessary
115     */
116    public ST getCurrentCPU() { 
117                ST retVal = this.getTypedField(2, 0);
118                return retVal;
119    }
120    
121    /**
122     * Returns
123     * NSC-2: "Current CPU" - creates it if necessary
124     */
125    public ST getNsc2_CurrentCPU() { 
126                ST retVal = this.getTypedField(2, 0);
127                return retVal;
128    }
129
130
131
132    /**
133     * Returns
134     * NSC-3: "Current Fileserver" - creates it if necessary
135     */
136    public ST getCurrentFileserver() { 
137                ST retVal = this.getTypedField(3, 0);
138                return retVal;
139    }
140    
141    /**
142     * Returns
143     * NSC-3: "Current Fileserver" - creates it if necessary
144     */
145    public ST getNsc3_CurrentFileserver() { 
146                ST retVal = this.getTypedField(3, 0);
147                return retVal;
148    }
149
150
151
152    /**
153     * Returns
154     * NSC-4: "Current Application" - creates it if necessary
155     */
156    public ST getCurrentApplication() { 
157                ST retVal = this.getTypedField(4, 0);
158                return retVal;
159    }
160    
161    /**
162     * Returns
163     * NSC-4: "Current Application" - creates it if necessary
164     */
165    public ST getNsc4_CurrentApplication() { 
166                ST retVal = this.getTypedField(4, 0);
167                return retVal;
168    }
169
170
171
172    /**
173     * Returns
174     * NSC-5: "Current Facility" - creates it if necessary
175     */
176    public ST getCurrentFacility() { 
177                ST retVal = this.getTypedField(5, 0);
178                return retVal;
179    }
180    
181    /**
182     * Returns
183     * NSC-5: "Current Facility" - creates it if necessary
184     */
185    public ST getNsc5_CurrentFacility() { 
186                ST retVal = this.getTypedField(5, 0);
187                return retVal;
188    }
189
190
191
192    /**
193     * Returns
194     * NSC-6: "New CPU" - creates it if necessary
195     */
196    public ST getNewCPU() { 
197                ST retVal = this.getTypedField(6, 0);
198                return retVal;
199    }
200    
201    /**
202     * Returns
203     * NSC-6: "New CPU" - creates it if necessary
204     */
205    public ST getNsc6_NewCPU() { 
206                ST retVal = this.getTypedField(6, 0);
207                return retVal;
208    }
209
210
211
212    /**
213     * Returns
214     * NSC-7: "New Fileserver" - creates it if necessary
215     */
216    public ST getNewFileserver() { 
217                ST retVal = this.getTypedField(7, 0);
218                return retVal;
219    }
220    
221    /**
222     * Returns
223     * NSC-7: "New Fileserver" - creates it if necessary
224     */
225    public ST getNsc7_NewFileserver() { 
226                ST retVal = this.getTypedField(7, 0);
227                return retVal;
228    }
229
230
231
232    /**
233     * Returns
234     * NSC-8: "New Application" - creates it if necessary
235     */
236    public ST getNewApplication() { 
237                ST retVal = this.getTypedField(8, 0);
238                return retVal;
239    }
240    
241    /**
242     * Returns
243     * NSC-8: "New Application" - creates it if necessary
244     */
245    public ST getNsc8_NewApplication() { 
246                ST retVal = this.getTypedField(8, 0);
247                return retVal;
248    }
249
250
251
252    /**
253     * Returns
254     * NSC-9: "New Facility" - creates it if necessary
255     */
256    public ST getNewFacility() { 
257                ST retVal = this.getTypedField(9, 0);
258                return retVal;
259    }
260    
261    /**
262     * Returns
263     * NSC-9: "New Facility" - creates it if necessary
264     */
265    public ST getNsc9_NewFacility() { 
266                ST retVal = this.getTypedField(9, 0);
267                return retVal;
268    }
269
270
271
272
273
274    /** {@inheritDoc} */   
275    protected Type createNewTypeWithoutReflection(int field) {
276       switch (field) {
277          case 0: return new ID(getMessage(), new Integer( 0 ));
278          case 1: return new ST(getMessage());
279          case 2: return new ST(getMessage());
280          case 3: return new ST(getMessage());
281          case 4: return new ST(getMessage());
282          case 5: return new ST(getMessage());
283          case 6: return new ST(getMessage());
284          case 7: return new ST(getMessage());
285          case 8: return new ST(getMessage());
286          default: return null;
287       }
288   }
289
290
291}
292