001
002
003
004
005
006
007
008
009
010
011
012
013
014
015
016
017package ca.uhn.fhir.model.dstu2.resource;
018
019import java.math.BigDecimal;
020import java.net.URI;
021import java.util.*;
022import ca.uhn.fhir.model.api.*;
023import ca.uhn.fhir.model.api.annotation.*;
024import ca.uhn.fhir.rest.gclient.*;
025
026import ca.uhn.fhir.model.dstu2.valueset.AccountStatusEnum;
027import ca.uhn.fhir.model.dstu2.valueset.ActionListEnum;
028import ca.uhn.fhir.model.dstu2.composite.AddressDt;
029import ca.uhn.fhir.model.dstu2.valueset.AdjudicationCodesEnum;
030import ca.uhn.fhir.model.dstu2.valueset.AdjudicationErrorCodesEnum;
031import ca.uhn.fhir.model.dstu2.valueset.AdjustmentReasonCodesEnum;
032import ca.uhn.fhir.model.dstu2.valueset.AdministrativeGenderEnum;
033import ca.uhn.fhir.model.dstu2.valueset.AdmitSourceEnum;
034import ca.uhn.fhir.model.dstu2.resource.AllergyIntolerance;
035import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceCategoryEnum;
036import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceCertaintyEnum;
037import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceCriticalityEnum;
038import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceSeverityEnum;
039import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceStatusEnum;
040import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceTypeEnum;
041import ca.uhn.fhir.model.dstu2.valueset.AnimalSpeciesEnum;
042import ca.uhn.fhir.model.dstu2.composite.AnnotationDt;
043import ca.uhn.fhir.model.dstu2.valueset.AnswerFormatEnum;
044import ca.uhn.fhir.model.dstu2.resource.Appointment;
045import ca.uhn.fhir.model.dstu2.valueset.AppointmentStatusEnum;
046import ca.uhn.fhir.model.dstu2.valueset.AssertionDirectionTypeEnum;
047import ca.uhn.fhir.model.dstu2.valueset.AssertionOperatorTypeEnum;
048import ca.uhn.fhir.model.dstu2.valueset.AssertionResponseTypesEnum;
049import ca.uhn.fhir.model.dstu2.composite.AttachmentDt;
050import ca.uhn.fhir.model.dstu2.valueset.AuditEventActionEnum;
051import ca.uhn.fhir.model.dstu2.valueset.AuditEventObjectLifecycleEnum;
052import ca.uhn.fhir.model.dstu2.valueset.AuditEventObjectRoleEnum;
053import ca.uhn.fhir.model.dstu2.valueset.AuditEventObjectTypeEnum;
054import ca.uhn.fhir.model.dstu2.valueset.AuditEventOutcomeEnum;
055import ca.uhn.fhir.model.dstu2.valueset.AuditEventParticipantNetworkTypeEnum;
056import ca.uhn.fhir.model.dstu2.valueset.AuditEventSourceTypeEnum;
057import ca.uhn.fhir.model.dstu2.valueset.BindingStrengthEnum;
058import ca.uhn.fhir.model.dstu2.resource.BodySite;
059import ca.uhn.fhir.model.dstu2.valueset.BundleTypeEnum;
060import ca.uhn.fhir.model.dstu2.resource.CarePlan;
061import ca.uhn.fhir.model.dstu2.valueset.CarePlanActivityCategoryEnum;
062import ca.uhn.fhir.model.dstu2.valueset.CarePlanActivityStatusEnum;
063import ca.uhn.fhir.model.dstu2.valueset.CarePlanRelationshipEnum;
064import ca.uhn.fhir.model.dstu2.valueset.CarePlanStatusEnum;
065import ca.uhn.fhir.model.dstu2.resource.Claim;
066import ca.uhn.fhir.model.dstu2.resource.ClaimResponse;
067import ca.uhn.fhir.model.dstu2.valueset.ClaimTypeEnum;
068import ca.uhn.fhir.model.dstu2.resource.ClinicalImpression;
069import ca.uhn.fhir.model.dstu2.valueset.ClinicalImpressionStatusEnum;
070import ca.uhn.fhir.model.dstu2.composite.CodeableConceptDt;
071import ca.uhn.fhir.model.dstu2.composite.CodingDt;
072import ca.uhn.fhir.model.dstu2.resource.CommunicationRequest;
073import ca.uhn.fhir.model.dstu2.valueset.CommunicationRequestStatusEnum;
074import ca.uhn.fhir.model.dstu2.valueset.CommunicationStatusEnum;
075import ca.uhn.fhir.model.dstu2.resource.Composition;
076import ca.uhn.fhir.model.dstu2.valueset.CompositionAttestationModeEnum;
077import ca.uhn.fhir.model.dstu2.valueset.CompositionStatusEnum;
078import ca.uhn.fhir.model.dstu2.valueset.ConceptMapEquivalenceEnum;
079import ca.uhn.fhir.model.dstu2.resource.Condition;
080import ca.uhn.fhir.model.dstu2.valueset.ConditionCategoryCodesEnum;
081import ca.uhn.fhir.model.dstu2.valueset.ConditionClinicalStatusCodesEnum;
082import ca.uhn.fhir.model.dstu2.valueset.ConditionVerificationStatusEnum;
083import ca.uhn.fhir.model.dstu2.valueset.ConditionalDeleteStatusEnum;
084import ca.uhn.fhir.model.dstu2.valueset.ConditionsCodesEnum;
085import ca.uhn.fhir.model.dstu2.resource.Conformance;
086import ca.uhn.fhir.model.dstu2.valueset.ConformanceEventModeEnum;
087import ca.uhn.fhir.model.dstu2.valueset.ConformanceResourceStatusEnum;
088import ca.uhn.fhir.model.dstu2.valueset.ConformanceStatementKindEnum;
089import ca.uhn.fhir.model.dstu2.composite.ContactPointDt;
090import ca.uhn.fhir.model.dstu2.valueset.ContentTypeEnum;
091import ca.uhn.fhir.model.dstu2.resource.Contract;
092import ca.uhn.fhir.model.dstu2.valueset.ContractActionCodesEnum;
093import ca.uhn.fhir.model.dstu2.valueset.ContractActorRoleCodesEnum;
094import ca.uhn.fhir.model.dstu2.valueset.ContractSubtypeCodesEnum;
095import ca.uhn.fhir.model.dstu2.valueset.ContractTermTypeCodesEnum;
096import ca.uhn.fhir.model.dstu2.valueset.ContractTypeCodesEnum;
097import ca.uhn.fhir.model.dstu2.resource.Coverage;
098import ca.uhn.fhir.model.dstu2.valueset.DataElementStringencyEnum;
099import ca.uhn.fhir.model.dstu2.valueset.DaysOfWeekEnum;
100import ca.uhn.fhir.model.dstu2.valueset.DetectedIssueSeverityEnum;
101import ca.uhn.fhir.model.dstu2.resource.Device;
102import ca.uhn.fhir.model.dstu2.resource.DeviceComponent;
103import ca.uhn.fhir.model.dstu2.resource.DeviceMetric;
104import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricCalibrationStateEnum;
105import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricCalibrationTypeEnum;
106import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricCategoryEnum;
107import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricColorEnum;
108import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricOperationalStatusEnum;
109import ca.uhn.fhir.model.dstu2.valueset.DeviceStatusEnum;
110import ca.uhn.fhir.model.dstu2.resource.DeviceUseRequest;
111import ca.uhn.fhir.model.dstu2.valueset.DeviceUseRequestPriorityEnum;
112import ca.uhn.fhir.model.dstu2.valueset.DeviceUseRequestStatusEnum;
113import ca.uhn.fhir.model.dstu2.resource.DiagnosticOrder;
114import ca.uhn.fhir.model.dstu2.valueset.DiagnosticOrderPriorityEnum;
115import ca.uhn.fhir.model.dstu2.valueset.DiagnosticOrderStatusEnum;
116import ca.uhn.fhir.model.dstu2.resource.DiagnosticReport;
117import ca.uhn.fhir.model.dstu2.valueset.DiagnosticReportStatusEnum;
118import ca.uhn.fhir.model.dstu2.valueset.DigitalMediaTypeEnum;
119import ca.uhn.fhir.model.dstu2.valueset.DocumentModeEnum;
120import ca.uhn.fhir.model.dstu2.resource.DocumentReference;
121import ca.uhn.fhir.model.dstu2.valueset.DocumentReferenceStatusEnum;
122import ca.uhn.fhir.model.dstu2.valueset.DocumentRelationshipTypeEnum;
123import ca.uhn.fhir.model.dstu2.composite.ElementDefinitionDt;
124import ca.uhn.fhir.model.dstu2.resource.EligibilityRequest;
125import ca.uhn.fhir.model.dstu2.resource.Encounter;
126import ca.uhn.fhir.model.dstu2.valueset.EncounterClassEnum;
127import ca.uhn.fhir.model.dstu2.valueset.EncounterLocationStatusEnum;
128import ca.uhn.fhir.model.dstu2.valueset.EncounterStateEnum;
129import ca.uhn.fhir.model.dstu2.valueset.EncounterTypeEnum;
130import ca.uhn.fhir.model.dstu2.resource.EnrollmentRequest;
131import ca.uhn.fhir.model.dstu2.valueset.EnteralFormulaTypeCodesEnum;
132import ca.uhn.fhir.model.dstu2.resource.EpisodeOfCare;
133import ca.uhn.fhir.model.dstu2.valueset.EpisodeOfCareStatusEnum;
134import ca.uhn.fhir.model.dstu2.valueset.ExceptionCodesEnum;
135import ca.uhn.fhir.model.dstu2.valueset.ExtensionContextEnum;
136import ca.uhn.fhir.model.dstu2.valueset.FamilyHistoryStatusEnum;
137import ca.uhn.fhir.model.dstu2.resource.FamilyMemberHistory;
138import ca.uhn.fhir.model.dstu2.valueset.FilterOperatorEnum;
139import ca.uhn.fhir.model.dstu2.valueset.FlagCategoryCodesEnum;
140import ca.uhn.fhir.model.dstu2.valueset.FlagStatusEnum;
141import ca.uhn.fhir.model.dstu2.valueset.FluidConsistencyTypeCodesEnum;
142import ca.uhn.fhir.model.dstu2.resource.Goal;
143import ca.uhn.fhir.model.dstu2.valueset.GoalCategoryEnum;
144import ca.uhn.fhir.model.dstu2.valueset.GoalPriorityEnum;
145import ca.uhn.fhir.model.dstu2.valueset.GoalStartEventEnum;
146import ca.uhn.fhir.model.dstu2.valueset.GoalStatusEnum;
147import ca.uhn.fhir.model.dstu2.valueset.GoalStatusReasonEnum;
148import ca.uhn.fhir.model.dstu2.resource.Group;
149import ca.uhn.fhir.model.dstu2.valueset.GroupTypeEnum;
150import ca.uhn.fhir.model.dstu2.valueset.GuideDependencyTypeEnum;
151import ca.uhn.fhir.model.dstu2.valueset.GuidePageKindEnum;
152import ca.uhn.fhir.model.dstu2.valueset.GuideResourcePurposeEnum;
153import ca.uhn.fhir.model.dstu2.valueset.HTTPVerbEnum;
154import ca.uhn.fhir.model.dstu2.resource.HealthcareService;
155import ca.uhn.fhir.model.dstu2.composite.HumanNameDt;
156import ca.uhn.fhir.model.dstu2.composite.IdentifierDt;
157import ca.uhn.fhir.model.dstu2.valueset.IdentifierTypeCodesEnum;
158import ca.uhn.fhir.model.dstu2.valueset.IdentityAssuranceLevelEnum;
159import ca.uhn.fhir.model.dstu2.resource.ImagingObjectSelection;
160import ca.uhn.fhir.model.dstu2.resource.ImagingStudy;
161import ca.uhn.fhir.model.dstu2.resource.Immunization;
162import ca.uhn.fhir.model.dstu2.valueset.ImmunizationReasonCodesEnum;
163import ca.uhn.fhir.model.dstu2.valueset.ImmunizationRecommendationDateCriterionCodesEnum;
164import ca.uhn.fhir.model.dstu2.valueset.ImmunizationRecommendationStatusCodesEnum;
165import ca.uhn.fhir.model.dstu2.valueset.ImmunizationRouteCodesEnum;
166import ca.uhn.fhir.model.dstu2.valueset.InstanceAvailabilityEnum;
167import ca.uhn.fhir.model.dstu2.valueset.InterventionCodesEnum;
168import ca.uhn.fhir.model.dstu2.valueset.IssueSeverityEnum;
169import ca.uhn.fhir.model.dstu2.valueset.IssueTypeEnum;
170import ca.uhn.fhir.model.dstu2.valueset.KOStitleEnum;
171import ca.uhn.fhir.model.dstu2.valueset.LateralityEnum;
172import ca.uhn.fhir.model.dstu2.valueset.LinkTypeEnum;
173import ca.uhn.fhir.model.dstu2.valueset.ListModeEnum;
174import ca.uhn.fhir.model.dstu2.valueset.ListOrderCodesEnum;
175import ca.uhn.fhir.model.dstu2.valueset.ListStatusEnum;
176import ca.uhn.fhir.model.dstu2.resource.Location;
177import ca.uhn.fhir.model.dstu2.valueset.LocationModeEnum;
178import ca.uhn.fhir.model.dstu2.valueset.LocationStatusEnum;
179import ca.uhn.fhir.model.dstu2.valueset.LocationTypeEnum;
180import ca.uhn.fhir.model.dstu2.valueset.MaritalStatusCodesEnum;
181import ca.uhn.fhir.model.dstu2.valueset.MeasmntPrincipleEnum;
182import ca.uhn.fhir.model.dstu2.resource.Media;
183import ca.uhn.fhir.model.dstu2.resource.Medication;
184import ca.uhn.fhir.model.dstu2.valueset.MedicationAdministrationStatusEnum;
185import ca.uhn.fhir.model.dstu2.valueset.MedicationDispenseStatusEnum;
186import ca.uhn.fhir.model.dstu2.resource.MedicationOrder;
187import ca.uhn.fhir.model.dstu2.valueset.MedicationOrderStatusEnum;
188import ca.uhn.fhir.model.dstu2.resource.MedicationStatement;
189import ca.uhn.fhir.model.dstu2.valueset.MedicationStatementStatusEnum;
190import ca.uhn.fhir.model.dstu2.valueset.MessageEventEnum;
191import ca.uhn.fhir.model.dstu2.valueset.MessageSignificanceCategoryEnum;
192import ca.uhn.fhir.model.dstu2.valueset.MessageTransportEnum;
193import ca.uhn.fhir.model.dstu2.resource.NamingSystem;
194import ca.uhn.fhir.model.dstu2.valueset.NamingSystemIdentifierTypeEnum;
195import ca.uhn.fhir.model.dstu2.valueset.NamingSystemTypeEnum;
196import ca.uhn.fhir.model.dstu2.valueset.NoteTypeEnum;
197import ca.uhn.fhir.model.dstu2.valueset.NutrientModifierCodesEnum;
198import ca.uhn.fhir.model.dstu2.resource.NutritionOrder;
199import ca.uhn.fhir.model.dstu2.valueset.NutritionOrderStatusEnum;
200import ca.uhn.fhir.model.dstu2.resource.Observation;
201import ca.uhn.fhir.model.dstu2.valueset.ObservationCategoryCodesEnum;
202import ca.uhn.fhir.model.dstu2.valueset.ObservationRelationshipTypeEnum;
203import ca.uhn.fhir.model.dstu2.valueset.ObservationStatusEnum;
204import ca.uhn.fhir.model.dstu2.resource.OperationDefinition;
205import ca.uhn.fhir.model.dstu2.valueset.OperationKindEnum;
206import ca.uhn.fhir.model.dstu2.resource.OperationOutcome;
207import ca.uhn.fhir.model.dstu2.valueset.OperationParameterUseEnum;
208import ca.uhn.fhir.model.dstu2.resource.Order;
209import ca.uhn.fhir.model.dstu2.valueset.OrderStatusEnum;
210import ca.uhn.fhir.model.dstu2.resource.Organization;
211import ca.uhn.fhir.model.dstu2.valueset.OrganizationTypeEnum;
212import ca.uhn.fhir.model.dstu2.valueset.ParticipantRequiredEnum;
213import ca.uhn.fhir.model.dstu2.valueset.ParticipantStatusEnum;
214import ca.uhn.fhir.model.dstu2.valueset.ParticipantTypeEnum;
215import ca.uhn.fhir.model.dstu2.valueset.ParticipationStatusEnum;
216import ca.uhn.fhir.model.dstu2.resource.Patient;
217import ca.uhn.fhir.model.dstu2.valueset.PayeeTypeCodesEnum;
218import ca.uhn.fhir.model.dstu2.valueset.PaymentStatusCodesEnum;
219import ca.uhn.fhir.model.dstu2.valueset.PaymentTypeCodesEnum;
220import ca.uhn.fhir.model.dstu2.composite.PeriodDt;
221import ca.uhn.fhir.model.dstu2.resource.Person;
222import ca.uhn.fhir.model.dstu2.resource.Practitioner;
223import ca.uhn.fhir.model.dstu2.valueset.PractitionerRoleEnum;
224import ca.uhn.fhir.model.dstu2.valueset.PractitionerSpecialtyEnum;
225import ca.uhn.fhir.model.dstu2.valueset.PriorityCodesEnum;
226import ca.uhn.fhir.model.dstu2.resource.Procedure;
227import ca.uhn.fhir.model.dstu2.resource.ProcedureRequest;
228import ca.uhn.fhir.model.dstu2.valueset.ProcedureRequestPriorityEnum;
229import ca.uhn.fhir.model.dstu2.valueset.ProcedureRequestStatusEnum;
230import ca.uhn.fhir.model.dstu2.valueset.ProcedureStatusEnum;
231import ca.uhn.fhir.model.dstu2.resource.ProcessRequest;
232import ca.uhn.fhir.model.dstu2.valueset.ProvenanceEntityRoleEnum;
233import ca.uhn.fhir.model.dstu2.composite.QuantityDt;
234import ca.uhn.fhir.model.dstu2.resource.Questionnaire;
235import ca.uhn.fhir.model.dstu2.resource.QuestionnaireResponse;
236import ca.uhn.fhir.model.dstu2.valueset.QuestionnaireResponseStatusEnum;
237import ca.uhn.fhir.model.dstu2.valueset.QuestionnaireStatusEnum;
238import ca.uhn.fhir.model.dstu2.composite.RangeDt;
239import ca.uhn.fhir.model.dstu2.composite.RatioDt;
240import ca.uhn.fhir.model.dstu2.valueset.ReferralMethodEnum;
241import ca.uhn.fhir.model.dstu2.resource.ReferralRequest;
242import ca.uhn.fhir.model.dstu2.valueset.ReferralStatusEnum;
243import ca.uhn.fhir.model.dstu2.resource.RelatedPerson;
244import ca.uhn.fhir.model.dstu2.valueset.RemittanceOutcomeEnum;
245import ca.uhn.fhir.model.dstu2.valueset.ResourceTypeEnum;
246import ca.uhn.fhir.model.dstu2.valueset.ResourceVersionPolicyEnum;
247import ca.uhn.fhir.model.dstu2.valueset.ResponseTypeEnum;
248import ca.uhn.fhir.model.dstu2.valueset.RestfulConformanceModeEnum;
249import ca.uhn.fhir.model.dstu2.valueset.RestfulSecurityServiceEnum;
250import ca.uhn.fhir.model.dstu2.resource.RiskAssessment;
251import ca.uhn.fhir.model.dstu2.valueset.RulesetCodesEnum;
252import ca.uhn.fhir.model.dstu2.composite.SampledDataDt;
253import ca.uhn.fhir.model.dstu2.resource.Schedule;
254import ca.uhn.fhir.model.dstu2.valueset.SearchEntryModeEnum;
255import ca.uhn.fhir.model.dstu2.valueset.SearchModifierCodeEnum;
256import ca.uhn.fhir.model.dstu2.valueset.SearchParamTypeEnum;
257import ca.uhn.fhir.model.dstu2.valueset.ServiceProvisionConditionsEnum;
258import ca.uhn.fhir.model.dstu2.composite.SignatureDt;
259import ca.uhn.fhir.model.dstu2.resource.Slot;
260import ca.uhn.fhir.model.dstu2.valueset.SlotStatusEnum;
261import ca.uhn.fhir.model.dstu2.resource.Specimen;
262import ca.uhn.fhir.model.dstu2.valueset.SpecimenCollectionMethodEnum;
263import ca.uhn.fhir.model.dstu2.valueset.SpecimenStatusEnum;
264import ca.uhn.fhir.model.dstu2.resource.StructureDefinition;
265import ca.uhn.fhir.model.dstu2.valueset.StructureDefinitionKindEnum;
266import ca.uhn.fhir.model.dstu2.valueset.SubscriptionChannelTypeEnum;
267import ca.uhn.fhir.model.dstu2.valueset.SubscriptionStatusEnum;
268import ca.uhn.fhir.model.dstu2.valueset.SubscriptionTagEnum;
269import ca.uhn.fhir.model.dstu2.resource.Substance;
270import ca.uhn.fhir.model.dstu2.valueset.SubstanceCategoryCodesEnum;
271import ca.uhn.fhir.model.dstu2.valueset.SupplementTypeCodesEnum;
272import ca.uhn.fhir.model.dstu2.valueset.SupplyDeliveryStatusEnum;
273import ca.uhn.fhir.model.dstu2.resource.SupplyRequest;
274import ca.uhn.fhir.model.dstu2.valueset.SupplyRequestReasonEnum;
275import ca.uhn.fhir.model.dstu2.valueset.SupplyRequestStatusEnum;
276import ca.uhn.fhir.model.dstu2.valueset.SurfaceCodesEnum;
277import ca.uhn.fhir.model.dstu2.valueset.SystemRestfulInteractionEnum;
278import ca.uhn.fhir.model.api.TemporalPrecisionEnum;
279import ca.uhn.fhir.model.dstu2.valueset.TextureModifiedFoodTypeCodesEnum;
280import ca.uhn.fhir.model.dstu2.valueset.TextureModifierCodesEnum;
281import ca.uhn.fhir.model.dstu2.composite.TimingDt;
282import ca.uhn.fhir.model.dstu2.valueset.TransactionModeEnum;
283import ca.uhn.fhir.model.dstu2.valueset.TypeRestfulInteractionEnum;
284import ca.uhn.fhir.model.dstu2.valueset.UDICodesEnum;
285import ca.uhn.fhir.model.dstu2.valueset.UnknownContentCodeEnum;
286import ca.uhn.fhir.model.dstu2.valueset.UseEnum;
287import ca.uhn.fhir.model.dstu2.resource.ValueSet;
288import ca.uhn.fhir.model.dstu2.valueset.VisionBaseEnum;
289import ca.uhn.fhir.model.dstu2.valueset.VisionEyesEnum;
290import ca.uhn.fhir.model.dstu2.resource.VisionPrescription;
291import ca.uhn.fhir.model.dstu2.valueset.XPathUsageTypeEnum;
292import ca.uhn.fhir.model.api.IResource;
293import ca.uhn.fhir.model.dstu2.composite.AgeDt;
294import ca.uhn.fhir.model.dstu2.composite.BoundCodeableConceptDt;
295import ca.uhn.fhir.model.dstu2.composite.DurationDt;
296import ca.uhn.fhir.model.dstu2.composite.MoneyDt;
297import ca.uhn.fhir.model.dstu2.composite.NarrativeDt;
298import ca.uhn.fhir.model.dstu2.composite.ResourceReferenceDt;
299import ca.uhn.fhir.model.dstu2.composite.SimpleQuantityDt;
300import ca.uhn.fhir.model.primitive.Base64BinaryDt;
301import ca.uhn.fhir.model.primitive.BooleanDt;
302import ca.uhn.fhir.model.primitive.BoundCodeDt;
303import ca.uhn.fhir.model.primitive.CodeDt;
304import ca.uhn.fhir.model.primitive.DateDt;
305import ca.uhn.fhir.model.primitive.DateTimeDt;
306import ca.uhn.fhir.model.primitive.DecimalDt;
307import ca.uhn.fhir.model.primitive.IdDt;
308import ca.uhn.fhir.model.primitive.InstantDt;
309import ca.uhn.fhir.model.primitive.IntegerDt;
310import ca.uhn.fhir.model.primitive.OidDt;
311import ca.uhn.fhir.model.primitive.PositiveIntDt;
312import ca.uhn.fhir.model.primitive.StringDt;
313import ca.uhn.fhir.model.primitive.TimeDt;
314import ca.uhn.fhir.model.primitive.UnsignedIntDt;
315import ca.uhn.fhir.model.primitive.UriDt;
316
317
318/**
319 * HAPI/FHIR <b>DeviceComponent</b> Resource
320 * ()
321 *
322 * <p>
323 * <b>Definition:</b>
324 * Describes the characteristics, operational status and capabilities of a medical-related component of a medical device.
325 * </p> 
326 *
327 * <p>
328 * <b>Requirements:</b>
329 * 
330 * </p> 
331 *
332 * <p>
333 * <b>Profile Definition:</b>
334 * <a href="http://hl7.org/fhir/profiles/DeviceComponent">http://hl7.org/fhir/profiles/DeviceComponent</a> 
335 * </p>
336 *
337 */
338@ResourceDef(name="DeviceComponent", profile="http://hl7.org/fhir/profiles/DeviceComponent", id="devicecomponent")
339public class DeviceComponent extends ca.uhn.fhir.model.dstu2.resource.BaseResource
340    implements  IResource     {
341
342        /**
343         * Search parameter constant for <b>parent</b>
344         * <p>
345         * Description: <b>The parent DeviceComponent resource</b><br>
346         * Type: <b>reference</b><br>
347         * Path: <b>DeviceComponent.parent</b><br>
348         * </p>
349         */
350        @SearchParamDefinition(name="parent", path="DeviceComponent.parent", description="The parent DeviceComponent resource", type="reference"  )
351        public static final String SP_PARENT = "parent";
352
353        /**
354         * <b>Fluent Client</b> search parameter constant for <b>parent</b>
355         * <p>
356         * Description: <b>The parent DeviceComponent resource</b><br>
357         * Type: <b>reference</b><br>
358         * Path: <b>DeviceComponent.parent</b><br>
359         * </p>
360         */
361        public static final ReferenceClientParam PARENT = new ReferenceClientParam(SP_PARENT);
362
363        /**
364         * Search parameter constant for <b>type</b>
365         * <p>
366         * Description: <b>The device component type</b><br>
367         * Type: <b>token</b><br>
368         * Path: <b>DeviceComponent.type</b><br>
369         * </p>
370         */
371        @SearchParamDefinition(name="type", path="DeviceComponent.type", description="The device component type", type="token"  )
372        public static final String SP_TYPE = "type";
373
374        /**
375         * <b>Fluent Client</b> search parameter constant for <b>type</b>
376         * <p>
377         * Description: <b>The device component type</b><br>
378         * Type: <b>token</b><br>
379         * Path: <b>DeviceComponent.type</b><br>
380         * </p>
381         */
382        public static final TokenClientParam TYPE = new TokenClientParam(SP_TYPE);
383
384        /**
385         * Search parameter constant for <b>source</b>
386         * <p>
387         * Description: <b>The device source</b><br>
388         * Type: <b>reference</b><br>
389         * Path: <b>DeviceComponent.source</b><br>
390         * </p>
391         */
392        @SearchParamDefinition(name="source", path="DeviceComponent.source", description="The device source", type="reference"  )
393        public static final String SP_SOURCE = "source";
394
395        /**
396         * <b>Fluent Client</b> search parameter constant for <b>source</b>
397         * <p>
398         * Description: <b>The device source</b><br>
399         * Type: <b>reference</b><br>
400         * Path: <b>DeviceComponent.source</b><br>
401         * </p>
402         */
403        public static final ReferenceClientParam SOURCE = new ReferenceClientParam(SP_SOURCE);
404
405
406        /**
407         * Constant for fluent queries to be used to add include statements. Specifies
408         * the path value of "<b>DeviceComponent:parent</b>".
409         */
410        public static final Include INCLUDE_PARENT = new Include("DeviceComponent:parent");
411
412        /**
413         * Constant for fluent queries to be used to add include statements. Specifies
414         * the path value of "<b>DeviceComponent:source</b>".
415         */
416        public static final Include INCLUDE_SOURCE = new Include("DeviceComponent:source");
417
418
419        @Child(name="type", type=CodeableConceptDt.class, order=0, min=1, max=1, summary=false, modifier=false) 
420        @Description(
421                shortDefinition="",
422                formalDefinition="Describes the specific component type as defined in the object-oriented or metric nomenclature partition."
423        )
424        private CodeableConceptDt myType;
425        
426        @Child(name="identifier", type=IdentifierDt.class, order=1, min=1, max=1, summary=false, modifier=false)        
427        @Description(
428                shortDefinition="",
429                formalDefinition="Describes the local assigned unique identification by the software. For example: handle ID."
430        )
431        private IdentifierDt myIdentifier;
432        
433        @Child(name="lastSystemChange", type=InstantDt.class, order=2, min=1, max=1, summary=false, modifier=false)     
434        @Description(
435                shortDefinition="",
436                formalDefinition="Describes the timestamp for the most recent system change which includes device configuration or setting change."
437        )
438        private InstantDt myLastSystemChange;
439        
440        @Child(name="source", order=3, min=0, max=1, summary=false, modifier=false, type={
441                ca.uhn.fhir.model.dstu2.resource.Device.class   })
442        @Description(
443                shortDefinition="",
444                formalDefinition="Describes the link to the source Device that contains administrative device information such as manufacture, serial number, etc."
445        )
446        private ResourceReferenceDt mySource;
447        
448        @Child(name="parent", order=4, min=0, max=1, summary=false, modifier=false, type={
449                ca.uhn.fhir.model.dstu2.resource.DeviceComponent.class  })
450        @Description(
451                shortDefinition="",
452                formalDefinition="Describes the link to the parent resource. For example: Channel is linked to its VMD parent."
453        )
454        private ResourceReferenceDt myParent;
455        
456        @Child(name="operationalStatus", type=CodeableConceptDt.class, order=5, min=0, max=Child.MAX_UNLIMITED, summary=false, modifier=false)  
457        @Description(
458                shortDefinition="",
459                formalDefinition="Indicates current operational status of the device. For example: On, Off, Standby, etc."
460        )
461        private java.util.List<CodeableConceptDt> myOperationalStatus;
462        
463        @Child(name="parameterGroup", type=CodeableConceptDt.class, order=6, min=0, max=1, summary=false, modifier=false)       
464        @Description(
465                shortDefinition="",
466                formalDefinition="Describes the parameter group supported by the current device component that is based on some nomenclature, e.g. cardiovascular."
467        )
468        private CodeableConceptDt myParameterGroup;
469        
470        @Child(name="measurementPrinciple", type=CodeDt.class, order=7, min=0, max=1, summary=false, modifier=false)    
471        @Description(
472                shortDefinition="",
473                formalDefinition="Describes the physical principle of the measurement. For example: thermal, chemical, acoustical, etc."
474        )
475        private BoundCodeDt<MeasmntPrincipleEnum> myMeasurementPrinciple;
476        
477        @Child(name="productionSpecification", order=8, min=0, max=Child.MAX_UNLIMITED, summary=false, modifier=false)  
478        @Description(
479                shortDefinition="",
480                formalDefinition="Describes the production specification such as component revision, serial number, etc."
481        )
482        private java.util.List<ProductionSpecification> myProductionSpecification;
483        
484        @Child(name="languageCode", type=CodeableConceptDt.class, order=9, min=0, max=1, summary=false, modifier=false) 
485        @Description(
486                shortDefinition="",
487                formalDefinition="Describes the language code for the human-readable text string produced by the device. This language code will follow the IETF language tag. Example: en-US."
488        )
489        private CodeableConceptDt myLanguageCode;
490        
491
492        @Override
493        public boolean isEmpty() {
494                return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(  myType,  myIdentifier,  myLastSystemChange,  mySource,  myParent,  myOperationalStatus,  myParameterGroup,  myMeasurementPrinciple,  myProductionSpecification,  myLanguageCode);
495        }
496        
497        @Override
498        public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
499                return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myType, myIdentifier, myLastSystemChange, mySource, myParent, myOperationalStatus, myParameterGroup, myMeasurementPrinciple, myProductionSpecification, myLanguageCode);
500        }
501
502        /**
503         * Gets the value(s) for <b>type</b> ().
504         * creating it if it does
505         * not exist. Will not return <code>null</code>.
506         *
507     * <p>
508     * <b>Definition:</b>
509     * Describes the specific component type as defined in the object-oriented or metric nomenclature partition.
510     * </p> 
511         */
512        public CodeableConceptDt getType() {  
513                if (myType == null) {
514                        myType = new CodeableConceptDt();
515                }
516                return myType;
517        }
518
519        /**
520         * Sets the value(s) for <b>type</b> ()
521         *
522     * <p>
523     * <b>Definition:</b>
524     * Describes the specific component type as defined in the object-oriented or metric nomenclature partition.
525     * </p> 
526         */
527        public DeviceComponent setType(CodeableConceptDt theValue) {
528                myType = theValue;
529                return this;
530        }
531        
532        
533
534  
535        /**
536         * Gets the value(s) for <b>identifier</b> ().
537         * creating it if it does
538         * not exist. Will not return <code>null</code>.
539         *
540     * <p>
541     * <b>Definition:</b>
542     * Describes the local assigned unique identification by the software. For example: handle ID.
543     * </p> 
544         */
545        public IdentifierDt getIdentifier() {  
546                if (myIdentifier == null) {
547                        myIdentifier = new IdentifierDt();
548                }
549                return myIdentifier;
550        }
551
552        /**
553         * Sets the value(s) for <b>identifier</b> ()
554         *
555     * <p>
556     * <b>Definition:</b>
557     * Describes the local assigned unique identification by the software. For example: handle ID.
558     * </p> 
559         */
560        public DeviceComponent setIdentifier(IdentifierDt theValue) {
561                myIdentifier = theValue;
562                return this;
563        }
564        
565        
566
567  
568        /**
569         * Gets the value(s) for <b>lastSystemChange</b> ().
570         * creating it if it does
571         * not exist. Will not return <code>null</code>.
572         *
573     * <p>
574     * <b>Definition:</b>
575     * Describes the timestamp for the most recent system change which includes device configuration or setting change.
576     * </p> 
577         */
578        public InstantDt getLastSystemChangeElement() {  
579                if (myLastSystemChange == null) {
580                        myLastSystemChange = new InstantDt();
581                }
582                return myLastSystemChange;
583        }
584
585        
586        /**
587         * Gets the value(s) for <b>lastSystemChange</b> ().
588         * creating it if it does
589         * not exist. Will not return <code>null</code>.
590         *
591     * <p>
592     * <b>Definition:</b>
593     * Describes the timestamp for the most recent system change which includes device configuration or setting change.
594     * </p> 
595         */
596        public Date getLastSystemChange() {  
597                return getLastSystemChangeElement().getValue();
598        }
599
600        /**
601         * Sets the value(s) for <b>lastSystemChange</b> ()
602         *
603     * <p>
604     * <b>Definition:</b>
605     * Describes the timestamp for the most recent system change which includes device configuration or setting change.
606     * </p> 
607         */
608        public DeviceComponent setLastSystemChange(InstantDt theValue) {
609                myLastSystemChange = theValue;
610                return this;
611        }
612        
613        
614
615        /**
616         * Sets the value for <b>lastSystemChange</b> ()
617         *
618     * <p>
619     * <b>Definition:</b>
620     * Describes the timestamp for the most recent system change which includes device configuration or setting change.
621     * </p> 
622         */
623        public DeviceComponent setLastSystemChangeWithMillisPrecision( Date theDate) {
624                myLastSystemChange = new InstantDt(theDate); 
625                return this; 
626        }
627
628        /**
629         * Sets the value for <b>lastSystemChange</b> ()
630         *
631     * <p>
632     * <b>Definition:</b>
633     * Describes the timestamp for the most recent system change which includes device configuration or setting change.
634     * </p> 
635         */
636        public DeviceComponent setLastSystemChange( Date theDate,  TemporalPrecisionEnum thePrecision) {
637                myLastSystemChange = new InstantDt(theDate, thePrecision); 
638                return this; 
639        }
640
641 
642        /**
643         * Gets the value(s) for <b>source</b> ().
644         * creating it if it does
645         * not exist. Will not return <code>null</code>.
646         *
647     * <p>
648     * <b>Definition:</b>
649     * Describes the link to the source Device that contains administrative device information such as manufacture, serial number, etc.
650     * </p> 
651         */
652        public ResourceReferenceDt getSource() {  
653                if (mySource == null) {
654                        mySource = new ResourceReferenceDt();
655                }
656                return mySource;
657        }
658
659        /**
660         * Sets the value(s) for <b>source</b> ()
661         *
662     * <p>
663     * <b>Definition:</b>
664     * Describes the link to the source Device that contains administrative device information such as manufacture, serial number, etc.
665     * </p> 
666         */
667        public DeviceComponent setSource(ResourceReferenceDt theValue) {
668                mySource = theValue;
669                return this;
670        }
671        
672        
673
674  
675        /**
676         * Gets the value(s) for <b>parent</b> ().
677         * creating it if it does
678         * not exist. Will not return <code>null</code>.
679         *
680     * <p>
681     * <b>Definition:</b>
682     * Describes the link to the parent resource. For example: Channel is linked to its VMD parent.
683     * </p> 
684         */
685        public ResourceReferenceDt getParent() {  
686                if (myParent == null) {
687                        myParent = new ResourceReferenceDt();
688                }
689                return myParent;
690        }
691
692        /**
693         * Sets the value(s) for <b>parent</b> ()
694         *
695     * <p>
696     * <b>Definition:</b>
697     * Describes the link to the parent resource. For example: Channel is linked to its VMD parent.
698     * </p> 
699         */
700        public DeviceComponent setParent(ResourceReferenceDt theValue) {
701                myParent = theValue;
702                return this;
703        }
704        
705        
706
707  
708        /**
709         * Gets the value(s) for <b>operationalStatus</b> ().
710         * creating it if it does
711         * not exist. Will not return <code>null</code>.
712         *
713     * <p>
714     * <b>Definition:</b>
715     * Indicates current operational status of the device. For example: On, Off, Standby, etc.
716     * </p> 
717         */
718        public java.util.List<CodeableConceptDt> getOperationalStatus() {  
719                if (myOperationalStatus == null) {
720                        myOperationalStatus = new java.util.ArrayList<CodeableConceptDt>();
721                }
722                return myOperationalStatus;
723        }
724
725        /**
726         * Sets the value(s) for <b>operationalStatus</b> ()
727         *
728     * <p>
729     * <b>Definition:</b>
730     * Indicates current operational status of the device. For example: On, Off, Standby, etc.
731     * </p> 
732         */
733        public DeviceComponent setOperationalStatus(java.util.List<CodeableConceptDt> theValue) {
734                myOperationalStatus = theValue;
735                return this;
736        }
737        
738        
739
740        /**
741         * Adds and returns a new value for <b>operationalStatus</b> ()
742         *
743     * <p>
744     * <b>Definition:</b>
745     * Indicates current operational status of the device. For example: On, Off, Standby, etc.
746     * </p> 
747         */
748        public CodeableConceptDt addOperationalStatus() {
749                CodeableConceptDt newType = new CodeableConceptDt();
750                getOperationalStatus().add(newType);
751                return newType; 
752        }
753
754        /**
755         * Adds a given new value for <b>operationalStatus</b> ()
756         *
757         * <p>
758         * <b>Definition:</b>
759         * Indicates current operational status of the device. For example: On, Off, Standby, etc.
760         * </p>
761         * @param theValue The operationalStatus to add (must not be <code>null</code>)
762         */
763        public DeviceComponent addOperationalStatus(CodeableConceptDt theValue) {
764                if (theValue == null) {
765                        throw new NullPointerException("theValue must not be null");
766                }
767                getOperationalStatus().add(theValue);
768                return this;
769        }
770
771        /**
772         * Gets the first repetition for <b>operationalStatus</b> (),
773         * creating it if it does not already exist.
774         *
775     * <p>
776     * <b>Definition:</b>
777     * Indicates current operational status of the device. For example: On, Off, Standby, etc.
778     * </p> 
779         */
780        public CodeableConceptDt getOperationalStatusFirstRep() {
781                if (getOperationalStatus().isEmpty()) {
782                        return addOperationalStatus();
783                }
784                return getOperationalStatus().get(0); 
785        }
786  
787        /**
788         * Gets the value(s) for <b>parameterGroup</b> ().
789         * creating it if it does
790         * not exist. Will not return <code>null</code>.
791         *
792     * <p>
793     * <b>Definition:</b>
794     * Describes the parameter group supported by the current device component that is based on some nomenclature, e.g. cardiovascular.
795     * </p> 
796         */
797        public CodeableConceptDt getParameterGroup() {  
798                if (myParameterGroup == null) {
799                        myParameterGroup = new CodeableConceptDt();
800                }
801                return myParameterGroup;
802        }
803
804        /**
805         * Sets the value(s) for <b>parameterGroup</b> ()
806         *
807     * <p>
808     * <b>Definition:</b>
809     * Describes the parameter group supported by the current device component that is based on some nomenclature, e.g. cardiovascular.
810     * </p> 
811         */
812        public DeviceComponent setParameterGroup(CodeableConceptDt theValue) {
813                myParameterGroup = theValue;
814                return this;
815        }
816        
817        
818
819  
820        /**
821         * Gets the value(s) for <b>measurementPrinciple</b> ().
822         * creating it if it does
823         * not exist. Will not return <code>null</code>.
824         *
825     * <p>
826     * <b>Definition:</b>
827     * Describes the physical principle of the measurement. For example: thermal, chemical, acoustical, etc.
828     * </p> 
829         */
830        public BoundCodeDt<MeasmntPrincipleEnum> getMeasurementPrincipleElement() {  
831                if (myMeasurementPrinciple == null) {
832                        myMeasurementPrinciple = new BoundCodeDt<MeasmntPrincipleEnum>(MeasmntPrincipleEnum.VALUESET_BINDER);
833                }
834                return myMeasurementPrinciple;
835        }
836
837        
838        /**
839         * Gets the value(s) for <b>measurementPrinciple</b> ().
840         * creating it if it does
841         * not exist. Will not return <code>null</code>.
842         *
843     * <p>
844     * <b>Definition:</b>
845     * Describes the physical principle of the measurement. For example: thermal, chemical, acoustical, etc.
846     * </p> 
847         */
848        public String getMeasurementPrinciple() {  
849                return getMeasurementPrincipleElement().getValue();
850        }
851
852        /**
853         * Sets the value(s) for <b>measurementPrinciple</b> ()
854         *
855     * <p>
856     * <b>Definition:</b>
857     * Describes the physical principle of the measurement. For example: thermal, chemical, acoustical, etc.
858     * </p> 
859         */
860        public DeviceComponent setMeasurementPrinciple(BoundCodeDt<MeasmntPrincipleEnum> theValue) {
861                myMeasurementPrinciple = theValue;
862                return this;
863        }
864        
865        
866
867        /**
868         * Sets the value(s) for <b>measurementPrinciple</b> ()
869         *
870     * <p>
871     * <b>Definition:</b>
872     * Describes the physical principle of the measurement. For example: thermal, chemical, acoustical, etc.
873     * </p> 
874         */
875        public DeviceComponent setMeasurementPrinciple(MeasmntPrincipleEnum theValue) {
876                setMeasurementPrinciple(new BoundCodeDt<MeasmntPrincipleEnum>(MeasmntPrincipleEnum.VALUESET_BINDER, theValue));
877                
878/*
879                getMeasurementPrincipleElement().setValueAsEnum(theValue);
880*/
881                return this;
882        }
883
884  
885        /**
886         * Gets the value(s) for <b>productionSpecification</b> ().
887         * creating it if it does
888         * not exist. Will not return <code>null</code>.
889         *
890     * <p>
891     * <b>Definition:</b>
892     * Describes the production specification such as component revision, serial number, etc.
893     * </p> 
894         */
895        public java.util.List<ProductionSpecification> getProductionSpecification() {  
896                if (myProductionSpecification == null) {
897                        myProductionSpecification = new java.util.ArrayList<ProductionSpecification>();
898                }
899                return myProductionSpecification;
900        }
901
902        /**
903         * Sets the value(s) for <b>productionSpecification</b> ()
904         *
905     * <p>
906     * <b>Definition:</b>
907     * Describes the production specification such as component revision, serial number, etc.
908     * </p> 
909         */
910        public DeviceComponent setProductionSpecification(java.util.List<ProductionSpecification> theValue) {
911                myProductionSpecification = theValue;
912                return this;
913        }
914        
915        
916
917        /**
918         * Adds and returns a new value for <b>productionSpecification</b> ()
919         *
920     * <p>
921     * <b>Definition:</b>
922     * Describes the production specification such as component revision, serial number, etc.
923     * </p> 
924         */
925        public ProductionSpecification addProductionSpecification() {
926                ProductionSpecification newType = new ProductionSpecification();
927                getProductionSpecification().add(newType);
928                return newType; 
929        }
930
931        /**
932         * Adds a given new value for <b>productionSpecification</b> ()
933         *
934         * <p>
935         * <b>Definition:</b>
936         * Describes the production specification such as component revision, serial number, etc.
937         * </p>
938         * @param theValue The productionSpecification to add (must not be <code>null</code>)
939         */
940        public DeviceComponent addProductionSpecification(ProductionSpecification theValue) {
941                if (theValue == null) {
942                        throw new NullPointerException("theValue must not be null");
943                }
944                getProductionSpecification().add(theValue);
945                return this;
946        }
947
948        /**
949         * Gets the first repetition for <b>productionSpecification</b> (),
950         * creating it if it does not already exist.
951         *
952     * <p>
953     * <b>Definition:</b>
954     * Describes the production specification such as component revision, serial number, etc.
955     * </p> 
956         */
957        public ProductionSpecification getProductionSpecificationFirstRep() {
958                if (getProductionSpecification().isEmpty()) {
959                        return addProductionSpecification();
960                }
961                return getProductionSpecification().get(0); 
962        }
963  
964        /**
965         * Gets the value(s) for <b>languageCode</b> ().
966         * creating it if it does
967         * not exist. Will not return <code>null</code>.
968         *
969     * <p>
970     * <b>Definition:</b>
971     * Describes the language code for the human-readable text string produced by the device. This language code will follow the IETF language tag. Example: en-US.
972     * </p> 
973         */
974        public CodeableConceptDt getLanguageCode() {  
975                if (myLanguageCode == null) {
976                        myLanguageCode = new CodeableConceptDt();
977                }
978                return myLanguageCode;
979        }
980
981        /**
982         * Sets the value(s) for <b>languageCode</b> ()
983         *
984     * <p>
985     * <b>Definition:</b>
986     * Describes the language code for the human-readable text string produced by the device. This language code will follow the IETF language tag. Example: en-US.
987     * </p> 
988         */
989        public DeviceComponent setLanguageCode(CodeableConceptDt theValue) {
990                myLanguageCode = theValue;
991                return this;
992        }
993        
994        
995
996  
997        /**
998         * Block class for child element: <b>DeviceComponent.productionSpecification</b> ()
999         *
1000     * <p>
1001     * <b>Definition:</b>
1002     * Describes the production specification such as component revision, serial number, etc.
1003     * </p> 
1004         */
1005        @Block()        
1006        public static class ProductionSpecification 
1007            extends  BaseIdentifiableElement        implements IResourceBlock {
1008        
1009        @Child(name="specType", type=CodeableConceptDt.class, order=0, min=0, max=1, summary=false, modifier=false)     
1010        @Description(
1011                shortDefinition="",
1012                formalDefinition="Describes the specification type, such as, serial number, part number, hardware revision, software revision, etc."
1013        )
1014        private CodeableConceptDt mySpecType;
1015        
1016        @Child(name="componentId", type=IdentifierDt.class, order=1, min=0, max=1, summary=false, modifier=false)       
1017        @Description(
1018                shortDefinition="",
1019                formalDefinition="Describes the internal component unique identification. This is a provision for manufacture specific standard components using a private OID. 11073-10101 has a partition for private OID semantic that the manufacture can make use of."
1020        )
1021        private IdentifierDt myComponentId;
1022        
1023        @Child(name="productionSpec", type=StringDt.class, order=2, min=0, max=1, summary=false, modifier=false)        
1024        @Description(
1025                shortDefinition="",
1026                formalDefinition="Describes the printable string defining the component."
1027        )
1028        private StringDt myProductionSpec;
1029        
1030
1031        @Override
1032        public boolean isEmpty() {
1033                return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(  mySpecType,  myComponentId,  myProductionSpec);
1034        }
1035        
1036        @Override
1037        public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
1038                return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, mySpecType, myComponentId, myProductionSpec);
1039        }
1040
1041        /**
1042         * Gets the value(s) for <b>specType</b> ().
1043         * creating it if it does
1044         * not exist. Will not return <code>null</code>.
1045         *
1046     * <p>
1047     * <b>Definition:</b>
1048     * Describes the specification type, such as, serial number, part number, hardware revision, software revision, etc.
1049     * </p> 
1050         */
1051        public CodeableConceptDt getSpecType() {  
1052                if (mySpecType == null) {
1053                        mySpecType = new CodeableConceptDt();
1054                }
1055                return mySpecType;
1056        }
1057
1058        /**
1059         * Sets the value(s) for <b>specType</b> ()
1060         *
1061     * <p>
1062     * <b>Definition:</b>
1063     * Describes the specification type, such as, serial number, part number, hardware revision, software revision, etc.
1064     * </p> 
1065         */
1066        public ProductionSpecification setSpecType(CodeableConceptDt theValue) {
1067                mySpecType = theValue;
1068                return this;
1069        }
1070        
1071        
1072
1073  
1074        /**
1075         * Gets the value(s) for <b>componentId</b> ().
1076         * creating it if it does
1077         * not exist. Will not return <code>null</code>.
1078         *
1079     * <p>
1080     * <b>Definition:</b>
1081     * Describes the internal component unique identification. This is a provision for manufacture specific standard components using a private OID. 11073-10101 has a partition for private OID semantic that the manufacture can make use of.
1082     * </p> 
1083         */
1084        public IdentifierDt getComponentId() {  
1085                if (myComponentId == null) {
1086                        myComponentId = new IdentifierDt();
1087                }
1088                return myComponentId;
1089        }
1090
1091        /**
1092         * Sets the value(s) for <b>componentId</b> ()
1093         *
1094     * <p>
1095     * <b>Definition:</b>
1096     * Describes the internal component unique identification. This is a provision for manufacture specific standard components using a private OID. 11073-10101 has a partition for private OID semantic that the manufacture can make use of.
1097     * </p> 
1098         */
1099        public ProductionSpecification setComponentId(IdentifierDt theValue) {
1100                myComponentId = theValue;
1101                return this;
1102        }
1103        
1104        
1105
1106  
1107        /**
1108         * Gets the value(s) for <b>productionSpec</b> ().
1109         * creating it if it does
1110         * not exist. Will not return <code>null</code>.
1111         *
1112     * <p>
1113     * <b>Definition:</b>
1114     * Describes the printable string defining the component.
1115     * </p> 
1116         */
1117        public StringDt getProductionSpecElement() {  
1118                if (myProductionSpec == null) {
1119                        myProductionSpec = new StringDt();
1120                }
1121                return myProductionSpec;
1122        }
1123
1124        
1125        /**
1126         * Gets the value(s) for <b>productionSpec</b> ().
1127         * creating it if it does
1128         * not exist. Will not return <code>null</code>.
1129         *
1130     * <p>
1131     * <b>Definition:</b>
1132     * Describes the printable string defining the component.
1133     * </p> 
1134         */
1135        public String getProductionSpec() {  
1136                return getProductionSpecElement().getValue();
1137        }
1138
1139        /**
1140         * Sets the value(s) for <b>productionSpec</b> ()
1141         *
1142     * <p>
1143     * <b>Definition:</b>
1144     * Describes the printable string defining the component.
1145     * </p> 
1146         */
1147        public ProductionSpecification setProductionSpec(StringDt theValue) {
1148                myProductionSpec = theValue;
1149                return this;
1150        }
1151        
1152        
1153
1154        /**
1155         * Sets the value for <b>productionSpec</b> ()
1156         *
1157     * <p>
1158     * <b>Definition:</b>
1159     * Describes the printable string defining the component.
1160     * </p> 
1161         */
1162        public ProductionSpecification setProductionSpec( String theString) {
1163                myProductionSpec = new StringDt(theString); 
1164                return this; 
1165        }
1166
1167 
1168
1169
1170        }
1171
1172
1173
1174
1175    @Override
1176    public String getResourceName() {
1177        return "DeviceComponent";
1178    }
1179    
1180    public ca.uhn.fhir.context.FhirVersionEnum getStructureFhirVersionEnum() {
1181        return ca.uhn.fhir.context.FhirVersionEnum.DSTU2;
1182    }
1183
1184
1185}