001/* 002 * #%L 003 * HAPI FHIR - Core Library 004 * %% 005 * Copyright (C) 2014 - 2025 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.model.api.annotation; 021 022import ca.uhn.fhir.model.api.IElement; 023 024import java.lang.annotation.ElementType; 025import java.lang.annotation.Retention; 026import java.lang.annotation.RetentionPolicy; 027import java.lang.annotation.Target; 028 029/** 030 * Field annotation for fields within resource and datatype definitions, indicating 031 * a child of that type. 032 */ 033@Retention(RetentionPolicy.RUNTIME) 034@Target(value = {ElementType.FIELD}) 035public @interface Child { 036 037 /** 038 * Constant value to supply for {@link #order()} when the order is defined 039 * elsewhere 040 */ 041 int ORDER_UNKNOWN = -1; 042 043 /** 044 * Constant value to supply for {@link #max()} to indicate '*' (no maximum) 045 */ 046 int MAX_UNLIMITED = -1; 047 048 /** 049 * Constant value to supply for {@link #order()} to indicate that this child should replace the 050 * entry in the superclass with the same name (and take its {@link Child#order() order} value 051 * in the process). This is useful if you wish to redefine an existing field in a resource/type 052 * definition in order to constrain/extend it. 053 */ 054 int REPLACE_PARENT = -2; 055 056 /** 057 * The name of this field, as it will appear in serialized versions of the message 058 */ 059 String name(); 060 061 /** 062 * The order in which this field comes within its parent. The first field should have a 063 * value of 0, the second a value of 1, etc. 064 */ 065 int order() default ORDER_UNKNOWN; 066 067 /** 068 * The minimum number of repetitions allowed for this child 069 */ 070 int min() default 0; 071 072 /** 073 * The maximum number of repetitions allowed for this child. Should be 074 * set to {@link #MAX_UNLIMITED} if there is no limit to the number of 075 * repetitions. 076 */ 077 int max() default 1; 078 079 /** 080 * Lists the allowable types for this field, if the field supports multiple 081 * types (otherwise does not need to be populated). 082 * <p> 083 * For example, if this field supports either DateTimeDt or BooleanDt types, 084 * those two classes should be supplied here. 085 * </p> 086 */ 087 Class<? extends IElement>[] type() default {}; 088 089 // Not implemented 090 // /** 091 // * This value is used when extending a built-in model class and defining a 092 // * field to replace a field within the built-in class. For example, the {@link Patient} 093 // * resource has a {@link Patient#getName() name} field, but if you wanted to extend Patient and 094 // * provide your own implementation of {@link HumanNameDt} (most likely your own subclass of 095 // * HumanNameDt which adds extensions of your choosing) you could do that using a replacement field. 096 // */ 097 // String replaces() default ""; 098 099 /** 100 * Is this element a modifier? 101 */ 102 boolean modifier() default false; 103 104 /** 105 * Should this element be included in the summary view 106 */ 107 boolean summary() default false; 108}