001/* 002 * #%L 003 * HAPI FHIR - Core Library 004 * %% 005 * Copyright (C) 2014 - 2023 Smile CDR, Inc. 006 * %% 007 * Licensed under the Apache License, Version 2.0 (the "License"); 008 * you may not use this file except in compliance with the License. 009 * You may obtain a copy of the License at 010 * 011 * http://www.apache.org/licenses/LICENSE-2.0 012 * 013 * Unless required by applicable law or agreed to in writing, software 014 * distributed under the License is distributed on an "AS IS" BASIS, 015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 016 * See the License for the specific language governing permissions and 017 * limitations under the License. 018 * #L% 019 */ 020package ca.uhn.fhir.context; 021 022import java.lang.reflect.Field; 023 024import org.apache.commons.lang3.Validate; 025import org.hl7.fhir.instance.model.api.IBase; 026 027import ca.uhn.fhir.model.api.IValueSetEnumBinder; 028import ca.uhn.fhir.model.api.annotation.Child; 029import ca.uhn.fhir.model.api.annotation.Description; 030 031public class RuntimeChildCompositeBoundDatatypeDefinition extends RuntimeChildCompositeDatatypeDefinition { 032 033 private IValueSetEnumBinder<Enum<?>> myBinder; 034 private Class<? extends Enum<?>> myEnumType; 035 036 public RuntimeChildCompositeBoundDatatypeDefinition(Field theField, String theElementName, Child theChildAnnotation, Description theDescriptionAnnotation, Class<? extends IBase> theDatatype, IValueSetEnumBinder<Enum<?>> theBinder, Class<? extends Enum<?>> theEnumType) { 037 super(theField, theElementName, theChildAnnotation, theDescriptionAnnotation, theDatatype); 038 Validate.notNull(theBinder, "theBinder must not be null"); 039 Validate.notNull(theEnumType, "theEnumType must not be null"); 040 041 myBinder = theBinder; 042 myEnumType = theEnumType; 043 } 044 045 @Override 046 public IValueSetEnumBinder<Enum<?>> getInstanceConstructorArguments() { 047 return myBinder; 048 } 049 050 @Override 051 public Class<? extends Enum<?>> getBoundEnumType() { 052 return myEnumType; 053 } 054 055}