001 002package ca.uhn.fhir.model.dstu2.valueset; 003 004import ca.uhn.fhir.model.api.*; 005import java.util.HashMap; 006import java.util.Map; 007 008public enum ExtensionContextEnum { 009 010 /** 011 * Display: <b>Resource</b><br> 012 * Code Value: <b>resource</b> 013 * 014 * The context is all elements matching a particular resource element path. 015 */ 016 RESOURCE("resource", "http://hl7.org/fhir/extension-context"), 017 018 /** 019 * Display: <b>Datatype</b><br> 020 * Code Value: <b>datatype</b> 021 * 022 * The context is all nodes matching a particular data type element path (root or repeating element) or all elements referencing a particular primitive data type (expressed as the datatype name). 023 */ 024 DATATYPE("datatype", "http://hl7.org/fhir/extension-context"), 025 026 /** 027 * Display: <b>Mapping</b><br> 028 * Code Value: <b>mapping</b> 029 * 030 * The context is all nodes whose mapping to a specified reference model corresponds to a particular mapping structure. The context identifies the mapping target. The mapping should clearly identify where such an extension could be used. 031 */ 032 MAPPING("mapping", "http://hl7.org/fhir/extension-context"), 033 034 /** 035 * Display: <b>Extension</b><br> 036 * Code Value: <b>extension</b> 037 * 038 * The context is a particular extension from a particular profile, a uri that identifies the extension definition. 039 */ 040 EXTENSION("extension", "http://hl7.org/fhir/extension-context"), 041 042 ; 043 044 /** 045 * Identifier for this Value Set: 046 * 047 */ 048 public static final String VALUESET_IDENTIFIER = ""; 049 050 /** 051 * Name for this Value Set: 052 * ExtensionContext 053 */ 054 public static final String VALUESET_NAME = "ExtensionContext"; 055 056 private static Map<String, ExtensionContextEnum> CODE_TO_ENUM = new HashMap<String, ExtensionContextEnum>(); 057 private static Map<String, Map<String, ExtensionContextEnum>> SYSTEM_TO_CODE_TO_ENUM = new HashMap<String, Map<String, ExtensionContextEnum>>(); 058 059 private final String myCode; 060 private final String mySystem; 061 062 static { 063 for (ExtensionContextEnum next : ExtensionContextEnum.values()) { 064 CODE_TO_ENUM.put(next.getCode(), next); 065 066 if (!SYSTEM_TO_CODE_TO_ENUM.containsKey(next.getSystem())) { 067 SYSTEM_TO_CODE_TO_ENUM.put(next.getSystem(), new HashMap<String, ExtensionContextEnum>()); 068 } 069 SYSTEM_TO_CODE_TO_ENUM.get(next.getSystem()).put(next.getCode(), next); 070 } 071 } 072 073 /** 074 * Returns the code associated with this enumerated value 075 */ 076 public String getCode() { 077 return myCode; 078 } 079 080 /** 081 * Returns the code system associated with this enumerated value 082 */ 083 public String getSystem() { 084 return mySystem; 085 } 086 087 /** 088 * Returns the enumerated value associated with this code 089 */ 090 public static ExtensionContextEnum forCode(String theCode) { 091 ExtensionContextEnum retVal = CODE_TO_ENUM.get(theCode); 092 return retVal; 093 } 094 095 /** 096 * Converts codes to their respective enumerated values 097 */ 098 public static final IValueSetEnumBinder<ExtensionContextEnum> VALUESET_BINDER = new IValueSetEnumBinder<ExtensionContextEnum>() { 099 @Override 100 public String toCodeString(ExtensionContextEnum theEnum) { 101 return theEnum.getCode(); 102 } 103 104 @Override 105 public String toSystemString(ExtensionContextEnum theEnum) { 106 return theEnum.getSystem(); 107 } 108 109 @Override 110 public ExtensionContextEnum fromCodeString(String theCodeString) { 111 return CODE_TO_ENUM.get(theCodeString); 112 } 113 114 @Override 115 public ExtensionContextEnum fromCodeString(String theCodeString, String theSystemString) { 116 Map<String, ExtensionContextEnum> map = SYSTEM_TO_CODE_TO_ENUM.get(theSystemString); 117 if (map == null) { 118 return null; 119 } 120 return map.get(theCodeString); 121 } 122 123 }; 124 125 /** 126 * Constructor 127 */ 128 ExtensionContextEnum(String theCode, String theSystem) { 129 myCode = theCode; 130 mySystem = theSystem; 131 } 132 133 134}