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>SupportingDocumentation</b> Resource
320 * ()
321 *
322 * <p>
323 * <b>Definition:</b>
324 * This resource provides the supporting information for a process, for example clinical or financial  information related to a claim or pre-authorization.
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/SupportingDocumentation">http://hl7.org/fhir/profiles/SupportingDocumentation</a> 
335 * </p>
336 *
337 */
338@ResourceDef(name="SupportingDocumentation", profile="http://hl7.org/fhir/profiles/SupportingDocumentation", id="supportingdocumentation")
339public class SupportingDocumentation extends ca.uhn.fhir.model.dstu2.resource.BaseResource
340    implements  IResource     {
341
342        /**
343         * Search parameter constant for <b>identifier</b>
344         * <p>
345         * Description: <b>The business identifier of the Eligibility</b><br>
346         * Type: <b>token</b><br>
347         * Path: <b>SupportingDocumentation.identifier</b><br>
348         * </p>
349         */
350        @SearchParamDefinition(name="identifier", path="SupportingDocumentation.identifier", description="The business identifier of the Eligibility", type="token"  )
351        public static final String SP_IDENTIFIER = "identifier";
352
353        /**
354         * <b>Fluent Client</b> search parameter constant for <b>identifier</b>
355         * <p>
356         * Description: <b>The business identifier of the Eligibility</b><br>
357         * Type: <b>token</b><br>
358         * Path: <b>SupportingDocumentation.identifier</b><br>
359         * </p>
360         */
361        public static final TokenClientParam IDENTIFIER = new TokenClientParam(SP_IDENTIFIER);
362
363        /**
364         * Search parameter constant for <b>author</b>
365         * <p>
366         * Description: <b>The person who generated this resource</b><br>
367         * Type: <b>reference</b><br>
368         * Path: <b>SupportingDocumentation.author</b><br>
369         * </p>
370         */
371        @SearchParamDefinition(name="author", path="SupportingDocumentation.author", description="The person who generated this resource", type="reference"  )
372        public static final String SP_AUTHOR = "author";
373
374        /**
375         * <b>Fluent Client</b> search parameter constant for <b>author</b>
376         * <p>
377         * Description: <b>The person who generated this resource</b><br>
378         * Type: <b>reference</b><br>
379         * Path: <b>SupportingDocumentation.author</b><br>
380         * </p>
381         */
382        public static final ReferenceClientParam AUTHOR = new ReferenceClientParam(SP_AUTHOR);
383
384        /**
385         * Search parameter constant for <b>subject</b>
386         * <p>
387         * Description: <b>The patient to  whom the documents refer</b><br>
388         * Type: <b>reference</b><br>
389         * Path: <b>SupportingDocumentation.subject</b><br>
390         * </p>
391         */
392        @SearchParamDefinition(name="subject", path="SupportingDocumentation.subject", description="The patient to  whom the documents refer", type="reference"  )
393        public static final String SP_SUBJECT = "subject";
394
395        /**
396         * <b>Fluent Client</b> search parameter constant for <b>subject</b>
397         * <p>
398         * Description: <b>The patient to  whom the documents refer</b><br>
399         * Type: <b>reference</b><br>
400         * Path: <b>SupportingDocumentation.subject</b><br>
401         * </p>
402         */
403        public static final ReferenceClientParam SUBJECT = new ReferenceClientParam(SP_SUBJECT);
404
405        /**
406         * Search parameter constant for <b>patient</b>
407         * <p>
408         * Description: <b>The patient to  whom the documents refer</b><br>
409         * Type: <b>reference</b><br>
410         * Path: <b>SupportingDocumentation.subject</b><br>
411         * </p>
412         */
413        @SearchParamDefinition(name="patient", path="SupportingDocumentation.subject", description="The patient to  whom the documents refer", type="reference"  )
414        public static final String SP_PATIENT = "patient";
415
416        /**
417         * <b>Fluent Client</b> search parameter constant for <b>patient</b>
418         * <p>
419         * Description: <b>The patient to  whom the documents refer</b><br>
420         * Type: <b>reference</b><br>
421         * Path: <b>SupportingDocumentation.subject</b><br>
422         * </p>
423         */
424        public static final ReferenceClientParam PATIENT = new ReferenceClientParam(SP_PATIENT);
425
426
427        /**
428         * Constant for fluent queries to be used to add include statements. Specifies
429         * the path value of "<b>SupportingDocumentation:author</b>".
430         */
431        public static final Include INCLUDE_AUTHOR = new Include("SupportingDocumentation:author");
432
433        /**
434         * Constant for fluent queries to be used to add include statements. Specifies
435         * the path value of "<b>SupportingDocumentation:patient</b>".
436         */
437        public static final Include INCLUDE_PATIENT = new Include("SupportingDocumentation:patient");
438
439        /**
440         * Constant for fluent queries to be used to add include statements. Specifies
441         * the path value of "<b>SupportingDocumentation:subject</b>".
442         */
443        public static final Include INCLUDE_SUBJECT = new Include("SupportingDocumentation:subject");
444
445
446        @Child(name="identifier", type=IdentifierDt.class, order=0, min=1, max=Child.MAX_UNLIMITED, summary=false, modifier=false)      
447        @Description(
448                shortDefinition="",
449                formalDefinition="The Response business identifier"
450        )
451        private java.util.List<IdentifierDt> myIdentifier;
452        
453        @Child(name="ruleset", type=CodingDt.class, order=1, min=0, max=1, summary=false, modifier=false)       
454        @Description(
455                shortDefinition="",
456                formalDefinition="The version of the style of resource contents. This should be mapped to the allowable profiles for this and supporting resources."
457        )
458        private CodingDt myRuleset;
459        
460        @Child(name="originalRuleset", type=CodingDt.class, order=2, min=0, max=1, summary=false, modifier=false)       
461        @Description(
462                shortDefinition="",
463                formalDefinition="The style (standard) and version of the original material which was converted into this resource."
464        )
465        private CodingDt myOriginalRuleset;
466        
467        @Child(name="created", type=DateTimeDt.class, order=3, min=0, max=1, summary=false, modifier=false)     
468        @Description(
469                shortDefinition="",
470                formalDefinition="The date when this resource was created."
471        )
472        private DateTimeDt myCreated;
473        
474        @Child(name="target", order=4, min=0, max=1, summary=false, modifier=false, type={
475                ca.uhn.fhir.model.dstu2.resource.Organization.class,            ca.uhn.fhir.model.dstu2.resource.Practitioner.class     })
476        @Description(
477                shortDefinition="",
478                formalDefinition="The Insurer, organization or Provider who is target  of the submission."
479        )
480        private ResourceReferenceDt myTarget;
481        
482        @Child(name="provider", order=5, min=0, max=1, summary=false, modifier=false, type={
483                ca.uhn.fhir.model.dstu2.resource.Practitioner.class     })
484        @Description(
485                shortDefinition="",
486                formalDefinition="The practitioner who is responsible for the services rendered to the patient."
487        )
488        private ResourceReferenceDt myProvider;
489        
490        @Child(name="organization", order=6, min=0, max=1, summary=false, modifier=false, type={
491                ca.uhn.fhir.model.dstu2.resource.Organization.class     })
492        @Description(
493                shortDefinition="",
494                formalDefinition="The organization which is responsible for the services rendered to the patient."
495        )
496        private ResourceReferenceDt myOrganization;
497        
498        @Child(name="request", order=7, min=0, max=1, summary=false, modifier=false, type={
499                IResource.class })
500        @Description(
501                shortDefinition="",
502                formalDefinition="Original request"
503        )
504        private ResourceReferenceDt myRequest;
505        
506        @Child(name="response", order=8, min=0, max=1, summary=false, modifier=false, type={
507                IResource.class })
508        @Description(
509                shortDefinition="",
510                formalDefinition="Original response"
511        )
512        private ResourceReferenceDt myResponse;
513        
514        @Child(name="author", order=9, min=0, max=1, summary=false, modifier=false, type={
515                ca.uhn.fhir.model.dstu2.resource.Practitioner.class     })
516        @Description(
517                shortDefinition="",
518                formalDefinition="Person who created the submission"
519        )
520        private ResourceReferenceDt myAuthor;
521        
522        @Child(name="subject", order=10, min=0, max=1, summary=false, modifier=false, type={
523                ca.uhn.fhir.model.dstu2.resource.Patient.class  })
524        @Description(
525                shortDefinition="",
526                formalDefinition="The patient who is directly or indirectly the subject of the supporting information."
527        )
528        private ResourceReferenceDt mySubject;
529        
530        @Child(name="detail", order=11, min=0, max=Child.MAX_UNLIMITED, summary=false, modifier=false)  
531        @Description(
532                shortDefinition="",
533                formalDefinition=""
534        )
535        private java.util.List<Detail> myDetail;
536        
537
538        @Override
539        public boolean isEmpty() {
540                return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(  myIdentifier,  myRuleset,  myOriginalRuleset,  myCreated,  myTarget,  myProvider,  myOrganization,  myRequest,  myResponse,  myAuthor,  mySubject,  myDetail);
541        }
542        
543        @Override
544        public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
545                return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myIdentifier, myRuleset, myOriginalRuleset, myCreated, myTarget, myProvider, myOrganization, myRequest, myResponse, myAuthor, mySubject, myDetail);
546        }
547
548        /**
549         * Gets the value(s) for <b>identifier</b> ().
550         * creating it if it does
551         * not exist. Will not return <code>null</code>.
552         *
553     * <p>
554     * <b>Definition:</b>
555     * The Response business identifier
556     * </p> 
557         */
558        public java.util.List<IdentifierDt> getIdentifier() {  
559                if (myIdentifier == null) {
560                        myIdentifier = new java.util.ArrayList<IdentifierDt>();
561                }
562                return myIdentifier;
563        }
564
565        /**
566         * Sets the value(s) for <b>identifier</b> ()
567         *
568     * <p>
569     * <b>Definition:</b>
570     * The Response business identifier
571     * </p> 
572         */
573        public SupportingDocumentation setIdentifier(java.util.List<IdentifierDt> theValue) {
574                myIdentifier = theValue;
575                return this;
576        }
577        
578        
579
580        /**
581         * Adds and returns a new value for <b>identifier</b> ()
582         *
583     * <p>
584     * <b>Definition:</b>
585     * The Response business identifier
586     * </p> 
587         */
588        public IdentifierDt addIdentifier() {
589                IdentifierDt newType = new IdentifierDt();
590                getIdentifier().add(newType);
591                return newType; 
592        }
593
594        /**
595         * Adds a given new value for <b>identifier</b> ()
596         *
597         * <p>
598         * <b>Definition:</b>
599         * The Response business identifier
600         * </p>
601         * @param theValue The identifier to add (must not be <code>null</code>)
602         */
603        public SupportingDocumentation addIdentifier(IdentifierDt theValue) {
604                if (theValue == null) {
605                        throw new NullPointerException("theValue must not be null");
606                }
607                getIdentifier().add(theValue);
608                return this;
609        }
610
611        /**
612         * Gets the first repetition for <b>identifier</b> (),
613         * creating it if it does not already exist.
614         *
615     * <p>
616     * <b>Definition:</b>
617     * The Response business identifier
618     * </p> 
619         */
620        public IdentifierDt getIdentifierFirstRep() {
621                if (getIdentifier().isEmpty()) {
622                        return addIdentifier();
623                }
624                return getIdentifier().get(0); 
625        }
626  
627        /**
628         * Gets the value(s) for <b>ruleset</b> ().
629         * creating it if it does
630         * not exist. Will not return <code>null</code>.
631         *
632     * <p>
633     * <b>Definition:</b>
634     * The version of the style of resource contents. This should be mapped to the allowable profiles for this and supporting resources.
635     * </p> 
636         */
637        public CodingDt getRuleset() {  
638                if (myRuleset == null) {
639                        myRuleset = new CodingDt();
640                }
641                return myRuleset;
642        }
643
644        /**
645         * Sets the value(s) for <b>ruleset</b> ()
646         *
647     * <p>
648     * <b>Definition:</b>
649     * The version of the style of resource contents. This should be mapped to the allowable profiles for this and supporting resources.
650     * </p> 
651         */
652        public SupportingDocumentation setRuleset(CodingDt theValue) {
653                myRuleset = theValue;
654                return this;
655        }
656        
657        
658
659  
660        /**
661         * Gets the value(s) for <b>originalRuleset</b> ().
662         * creating it if it does
663         * not exist. Will not return <code>null</code>.
664         *
665     * <p>
666     * <b>Definition:</b>
667     * The style (standard) and version of the original material which was converted into this resource.
668     * </p> 
669         */
670        public CodingDt getOriginalRuleset() {  
671                if (myOriginalRuleset == null) {
672                        myOriginalRuleset = new CodingDt();
673                }
674                return myOriginalRuleset;
675        }
676
677        /**
678         * Sets the value(s) for <b>originalRuleset</b> ()
679         *
680     * <p>
681     * <b>Definition:</b>
682     * The style (standard) and version of the original material which was converted into this resource.
683     * </p> 
684         */
685        public SupportingDocumentation setOriginalRuleset(CodingDt theValue) {
686                myOriginalRuleset = theValue;
687                return this;
688        }
689        
690        
691
692  
693        /**
694         * Gets the value(s) for <b>created</b> ().
695         * creating it if it does
696         * not exist. Will not return <code>null</code>.
697         *
698     * <p>
699     * <b>Definition:</b>
700     * The date when this resource was created.
701     * </p> 
702         */
703        public DateTimeDt getCreatedElement() {  
704                if (myCreated == null) {
705                        myCreated = new DateTimeDt();
706                }
707                return myCreated;
708        }
709
710        
711        /**
712         * Gets the value(s) for <b>created</b> ().
713         * creating it if it does
714         * not exist. Will not return <code>null</code>.
715         *
716     * <p>
717     * <b>Definition:</b>
718     * The date when this resource was created.
719     * </p> 
720         */
721        public Date getCreated() {  
722                return getCreatedElement().getValue();
723        }
724
725        /**
726         * Sets the value(s) for <b>created</b> ()
727         *
728     * <p>
729     * <b>Definition:</b>
730     * The date when this resource was created.
731     * </p> 
732         */
733        public SupportingDocumentation setCreated(DateTimeDt theValue) {
734                myCreated = theValue;
735                return this;
736        }
737        
738        
739
740        /**
741         * Sets the value for <b>created</b> ()
742         *
743     * <p>
744     * <b>Definition:</b>
745     * The date when this resource was created.
746     * </p> 
747         */
748        public SupportingDocumentation setCreated( Date theDate,  TemporalPrecisionEnum thePrecision) {
749                myCreated = new DateTimeDt(theDate, thePrecision); 
750                return this; 
751        }
752
753        /**
754         * Sets the value for <b>created</b> ()
755         *
756     * <p>
757     * <b>Definition:</b>
758     * The date when this resource was created.
759     * </p> 
760         */
761        public SupportingDocumentation setCreatedWithSecondsPrecision( Date theDate) {
762                myCreated = new DateTimeDt(theDate); 
763                return this; 
764        }
765
766 
767        /**
768         * Gets the value(s) for <b>target</b> ().
769         * creating it if it does
770         * not exist. Will not return <code>null</code>.
771         *
772     * <p>
773     * <b>Definition:</b>
774     * The Insurer, organization or Provider who is target  of the submission.
775     * </p> 
776         */
777        public ResourceReferenceDt getTarget() {  
778                if (myTarget == null) {
779                        myTarget = new ResourceReferenceDt();
780                }
781                return myTarget;
782        }
783
784        /**
785         * Sets the value(s) for <b>target</b> ()
786         *
787     * <p>
788     * <b>Definition:</b>
789     * The Insurer, organization or Provider who is target  of the submission.
790     * </p> 
791         */
792        public SupportingDocumentation setTarget(ResourceReferenceDt theValue) {
793                myTarget = theValue;
794                return this;
795        }
796        
797        
798
799  
800        /**
801         * Gets the value(s) for <b>provider</b> ().
802         * creating it if it does
803         * not exist. Will not return <code>null</code>.
804         *
805     * <p>
806     * <b>Definition:</b>
807     * The practitioner who is responsible for the services rendered to the patient.
808     * </p> 
809         */
810        public ResourceReferenceDt getProvider() {  
811                if (myProvider == null) {
812                        myProvider = new ResourceReferenceDt();
813                }
814                return myProvider;
815        }
816
817        /**
818         * Sets the value(s) for <b>provider</b> ()
819         *
820     * <p>
821     * <b>Definition:</b>
822     * The practitioner who is responsible for the services rendered to the patient.
823     * </p> 
824         */
825        public SupportingDocumentation setProvider(ResourceReferenceDt theValue) {
826                myProvider = theValue;
827                return this;
828        }
829        
830        
831
832  
833        /**
834         * Gets the value(s) for <b>organization</b> ().
835         * creating it if it does
836         * not exist. Will not return <code>null</code>.
837         *
838     * <p>
839     * <b>Definition:</b>
840     * The organization which is responsible for the services rendered to the patient.
841     * </p> 
842         */
843        public ResourceReferenceDt getOrganization() {  
844                if (myOrganization == null) {
845                        myOrganization = new ResourceReferenceDt();
846                }
847                return myOrganization;
848        }
849
850        /**
851         * Sets the value(s) for <b>organization</b> ()
852         *
853     * <p>
854     * <b>Definition:</b>
855     * The organization which is responsible for the services rendered to the patient.
856     * </p> 
857         */
858        public SupportingDocumentation setOrganization(ResourceReferenceDt theValue) {
859                myOrganization = theValue;
860                return this;
861        }
862        
863        
864
865  
866        /**
867         * Gets the value(s) for <b>request</b> ().
868         * creating it if it does
869         * not exist. Will not return <code>null</code>.
870         *
871     * <p>
872     * <b>Definition:</b>
873     * Original request
874     * </p> 
875         */
876        public ResourceReferenceDt getRequest() {  
877                if (myRequest == null) {
878                        myRequest = new ResourceReferenceDt();
879                }
880                return myRequest;
881        }
882
883        /**
884         * Sets the value(s) for <b>request</b> ()
885         *
886     * <p>
887     * <b>Definition:</b>
888     * Original request
889     * </p> 
890         */
891        public SupportingDocumentation setRequest(ResourceReferenceDt theValue) {
892                myRequest = theValue;
893                return this;
894        }
895        
896        
897
898  
899        /**
900         * Gets the value(s) for <b>response</b> ().
901         * creating it if it does
902         * not exist. Will not return <code>null</code>.
903         *
904     * <p>
905     * <b>Definition:</b>
906     * Original response
907     * </p> 
908         */
909        public ResourceReferenceDt getResponse() {  
910                if (myResponse == null) {
911                        myResponse = new ResourceReferenceDt();
912                }
913                return myResponse;
914        }
915
916        /**
917         * Sets the value(s) for <b>response</b> ()
918         *
919     * <p>
920     * <b>Definition:</b>
921     * Original response
922     * </p> 
923         */
924        public SupportingDocumentation setResponse(ResourceReferenceDt theValue) {
925                myResponse = theValue;
926                return this;
927        }
928        
929        
930
931  
932        /**
933         * Gets the value(s) for <b>author</b> ().
934         * creating it if it does
935         * not exist. Will not return <code>null</code>.
936         *
937     * <p>
938     * <b>Definition:</b>
939     * Person who created the submission
940     * </p> 
941         */
942        public ResourceReferenceDt getAuthor() {  
943                if (myAuthor == null) {
944                        myAuthor = new ResourceReferenceDt();
945                }
946                return myAuthor;
947        }
948
949        /**
950         * Sets the value(s) for <b>author</b> ()
951         *
952     * <p>
953     * <b>Definition:</b>
954     * Person who created the submission
955     * </p> 
956         */
957        public SupportingDocumentation setAuthor(ResourceReferenceDt theValue) {
958                myAuthor = theValue;
959                return this;
960        }
961        
962        
963
964  
965        /**
966         * Gets the value(s) for <b>subject</b> ().
967         * creating it if it does
968         * not exist. Will not return <code>null</code>.
969         *
970     * <p>
971     * <b>Definition:</b>
972     * The patient who is directly or indirectly the subject of the supporting information.
973     * </p> 
974         */
975        public ResourceReferenceDt getSubject() {  
976                if (mySubject == null) {
977                        mySubject = new ResourceReferenceDt();
978                }
979                return mySubject;
980        }
981
982        /**
983         * Sets the value(s) for <b>subject</b> ()
984         *
985     * <p>
986     * <b>Definition:</b>
987     * The patient who is directly or indirectly the subject of the supporting information.
988     * </p> 
989         */
990        public SupportingDocumentation setSubject(ResourceReferenceDt theValue) {
991                mySubject = theValue;
992                return this;
993        }
994        
995        
996
997  
998        /**
999         * Gets the value(s) for <b>detail</b> ().
1000         * creating it if it does
1001         * not exist. Will not return <code>null</code>.
1002         *
1003     * <p>
1004     * <b>Definition:</b>
1005     * 
1006     * </p> 
1007         */
1008        public java.util.List<Detail> getDetail() {  
1009                if (myDetail == null) {
1010                        myDetail = new java.util.ArrayList<Detail>();
1011                }
1012                return myDetail;
1013        }
1014
1015        /**
1016         * Sets the value(s) for <b>detail</b> ()
1017         *
1018     * <p>
1019     * <b>Definition:</b>
1020     * 
1021     * </p> 
1022         */
1023        public SupportingDocumentation setDetail(java.util.List<Detail> theValue) {
1024                myDetail = theValue;
1025                return this;
1026        }
1027        
1028        
1029
1030        /**
1031         * Adds and returns a new value for <b>detail</b> ()
1032         *
1033     * <p>
1034     * <b>Definition:</b>
1035     * 
1036     * </p> 
1037         */
1038        public Detail addDetail() {
1039                Detail newType = new Detail();
1040                getDetail().add(newType);
1041                return newType; 
1042        }
1043
1044        /**
1045         * Adds a given new value for <b>detail</b> ()
1046         *
1047         * <p>
1048         * <b>Definition:</b>
1049         * 
1050         * </p>
1051         * @param theValue The detail to add (must not be <code>null</code>)
1052         */
1053        public SupportingDocumentation addDetail(Detail theValue) {
1054                if (theValue == null) {
1055                        throw new NullPointerException("theValue must not be null");
1056                }
1057                getDetail().add(theValue);
1058                return this;
1059        }
1060
1061        /**
1062         * Gets the first repetition for <b>detail</b> (),
1063         * creating it if it does not already exist.
1064         *
1065     * <p>
1066     * <b>Definition:</b>
1067     * 
1068     * </p> 
1069         */
1070        public Detail getDetailFirstRep() {
1071                if (getDetail().isEmpty()) {
1072                        return addDetail();
1073                }
1074                return getDetail().get(0); 
1075        }
1076  
1077        /**
1078         * Block class for child element: <b>SupportingDocumentation.detail</b> ()
1079         *
1080     * <p>
1081     * <b>Definition:</b>
1082     * 
1083     * </p> 
1084         */
1085        @Block()        
1086        public static class Detail 
1087            extends  BaseIdentifiableElement        implements IResourceBlock {
1088        
1089        @Child(name="linkId", type=IntegerDt.class, order=0, min=1, max=1, summary=false, modifier=false)       
1090        @Description(
1091                shortDefinition="",
1092                formalDefinition="A link Id for the response to reference."
1093        )
1094        private IntegerDt myLinkId;
1095        
1096        @Child(name="content", order=1, min=1, max=1, summary=false, modifier=false, type={
1097                IResource.class,                AttachmentDt.class      })
1098        @Description(
1099                shortDefinition="",
1100                formalDefinition="The attached content."
1101        )
1102        private IDatatype myContent;
1103        
1104        @Child(name="dateTime", type=DateTimeDt.class, order=2, min=0, max=1, summary=false, modifier=false)    
1105        @Description(
1106                shortDefinition="",
1107                formalDefinition="The date and optionally time when the material was created."
1108        )
1109        private DateTimeDt myDateTime;
1110        
1111
1112        @Override
1113        public boolean isEmpty() {
1114                return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(  myLinkId,  myContent,  myDateTime);
1115        }
1116        
1117        @Override
1118        public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
1119                return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myLinkId, myContent, myDateTime);
1120        }
1121
1122        /**
1123         * Gets the value(s) for <b>linkId</b> ().
1124         * creating it if it does
1125         * not exist. Will not return <code>null</code>.
1126         *
1127     * <p>
1128     * <b>Definition:</b>
1129     * A link Id for the response to reference.
1130     * </p> 
1131         */
1132        public IntegerDt getLinkIdElement() {  
1133                if (myLinkId == null) {
1134                        myLinkId = new IntegerDt();
1135                }
1136                return myLinkId;
1137        }
1138
1139        
1140        /**
1141         * Gets the value(s) for <b>linkId</b> ().
1142         * creating it if it does
1143         * not exist. Will not return <code>null</code>.
1144         *
1145     * <p>
1146     * <b>Definition:</b>
1147     * A link Id for the response to reference.
1148     * </p> 
1149         */
1150        public Integer getLinkId() {  
1151                return getLinkIdElement().getValue();
1152        }
1153
1154        /**
1155         * Sets the value(s) for <b>linkId</b> ()
1156         *
1157     * <p>
1158     * <b>Definition:</b>
1159     * A link Id for the response to reference.
1160     * </p> 
1161         */
1162        public Detail setLinkId(IntegerDt theValue) {
1163                myLinkId = theValue;
1164                return this;
1165        }
1166        
1167        
1168
1169        /**
1170         * Sets the value for <b>linkId</b> ()
1171         *
1172     * <p>
1173     * <b>Definition:</b>
1174     * A link Id for the response to reference.
1175     * </p> 
1176         */
1177        public Detail setLinkId( int theInteger) {
1178                myLinkId = new IntegerDt(theInteger); 
1179                return this; 
1180        }
1181
1182 
1183        /**
1184         * Gets the value(s) for <b>content[x]</b> ().
1185         * creating it if it does
1186         * not exist. Will not return <code>null</code>.
1187         *
1188     * <p>
1189     * <b>Definition:</b>
1190     * The attached content.
1191     * </p> 
1192         */
1193        public IDatatype getContent() {  
1194                return myContent;
1195        }
1196
1197        /**
1198         * Sets the value(s) for <b>content[x]</b> ()
1199         *
1200     * <p>
1201     * <b>Definition:</b>
1202     * The attached content.
1203     * </p> 
1204         */
1205        public Detail setContent(IDatatype theValue) {
1206                myContent = theValue;
1207                return this;
1208        }
1209        
1210        
1211
1212  
1213        /**
1214         * Gets the value(s) for <b>dateTime</b> ().
1215         * creating it if it does
1216         * not exist. Will not return <code>null</code>.
1217         *
1218     * <p>
1219     * <b>Definition:</b>
1220     * The date and optionally time when the material was created.
1221     * </p> 
1222         */
1223        public DateTimeDt getDateTimeElement() {  
1224                if (myDateTime == null) {
1225                        myDateTime = new DateTimeDt();
1226                }
1227                return myDateTime;
1228        }
1229
1230        
1231        /**
1232         * Gets the value(s) for <b>dateTime</b> ().
1233         * creating it if it does
1234         * not exist. Will not return <code>null</code>.
1235         *
1236     * <p>
1237     * <b>Definition:</b>
1238     * The date and optionally time when the material was created.
1239     * </p> 
1240         */
1241        public Date getDateTime() {  
1242                return getDateTimeElement().getValue();
1243        }
1244
1245        /**
1246         * Sets the value(s) for <b>dateTime</b> ()
1247         *
1248     * <p>
1249     * <b>Definition:</b>
1250     * The date and optionally time when the material was created.
1251     * </p> 
1252         */
1253        public Detail setDateTime(DateTimeDt theValue) {
1254                myDateTime = theValue;
1255                return this;
1256        }
1257        
1258        
1259
1260        /**
1261         * Sets the value for <b>dateTime</b> ()
1262         *
1263     * <p>
1264     * <b>Definition:</b>
1265     * The date and optionally time when the material was created.
1266     * </p> 
1267         */
1268        public Detail setDateTime( Date theDate,  TemporalPrecisionEnum thePrecision) {
1269                myDateTime = new DateTimeDt(theDate, thePrecision); 
1270                return this; 
1271        }
1272
1273        /**
1274         * Sets the value for <b>dateTime</b> ()
1275         *
1276     * <p>
1277     * <b>Definition:</b>
1278     * The date and optionally time when the material was created.
1279     * </p> 
1280         */
1281        public Detail setDateTimeWithSecondsPrecision( Date theDate) {
1282                myDateTime = new DateTimeDt(theDate); 
1283                return this; 
1284        }
1285
1286 
1287
1288
1289        }
1290
1291
1292
1293
1294    @Override
1295    public String getResourceName() {
1296        return "SupportingDocumentation";
1297    }
1298    
1299    public ca.uhn.fhir.context.FhirVersionEnum getStructureFhirVersionEnum() {
1300        return ca.uhn.fhir.context.FhirVersionEnum.DSTU2;
1301    }
1302
1303
1304}