ca.uhn.fhir.context.RuntimeExtensionDtDefinition Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hapi-fhir-base Show documentation
Show all versions of hapi-fhir-base Show documentation
Builds the hapi fhir base. Requires Common lang, commons-text, and guava be built first.
/*
* #%L
* HAPI FHIR - Core Library
* %%
* Copyright (C) 2014 - 2024 Smile CDR, Inc.
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
package ca.uhn.fhir.context;
import ca.uhn.fhir.model.api.annotation.DatatypeDef;
import org.hl7.fhir.instance.model.api.IBase;
import org.hl7.fhir.instance.model.api.ICompositeType;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
public class RuntimeExtensionDtDefinition extends RuntimeCompositeDatatypeDefinition {
private List myChildren;
public RuntimeExtensionDtDefinition(
DatatypeDef theDef,
Class extends ICompositeType> theImplementingClass,
boolean theStandardType,
FhirContext theContext,
Map, BaseRuntimeElementDefinition>> theClassToElementDefinitions) {
super(theDef, theImplementingClass, theStandardType, theContext, theClassToElementDefinitions);
}
@Override
public List getChildren() {
return myChildren;
}
public List getChildrenIncludingUrl() {
return super.getChildren();
}
@Override
public void sealAndInitialize(
FhirContext theContext,
Map, BaseRuntimeElementDefinition>> theClassToElementDefinitions) {
super.sealAndInitialize(theContext, theClassToElementDefinitions);
/*
* The "url" child is a weird child because it is not parsed and encoded in the normal way,
* so we exclude it here
*/
List superChildren = super.getChildren();
ArrayList children = new ArrayList();
for (BaseRuntimeChildDefinition baseRuntimeChildDefinition : superChildren) {
if (baseRuntimeChildDefinition.getValidChildNames().contains("url")) {
continue;
}
children.add(baseRuntimeChildDefinition);
}
myChildren = Collections.unmodifiableList(children);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy