001package org.hl7.fhir.r4.model.codesystems;
002
003/*
004  Copyright (c) 2011+, HL7, Inc.
005  All rights reserved.
006  
007  Redistribution and use in source and binary forms, with or without modification, 
008  are permitted provided that the following conditions are met:
009  
010   * Redistributions of source code must retain the above copyright notice, this 
011     list of conditions and the following disclaimer.
012   * Redistributions in binary form must reproduce the above copyright notice, 
013     this list of conditions and the following disclaimer in the documentation 
014     and/or other materials provided with the distribution.
015   * Neither the name of HL7 nor the names of its contributors may be used to 
016     endorse or promote products derived from this software without specific 
017     prior written permission.
018  
019  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
020  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
021  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
022  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
023  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
024  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
025  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
026  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
027  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
028  POSSIBILITY OF SUCH DAMAGE.
029  
030*/
031
032// Generated on Wed, Jan 30, 2019 16:19-0500 for FHIR v4.0.0
033
034import org.hl7.fhir.exceptions.FHIRException;
035
036public enum ExtensionContextType {
037
038  /**
039   * The context is all elements that match the FHIRPath query found in the
040   * expression.
041   */
042  FHIRPATH,
043  /**
044   * The context is any element that has an ElementDefinition.id that matches that
045   * found in the expression. This includes ElementDefinition Ids that have
046   * slicing identifiers. The full path for the element is [url]#[elementid]. If
047   * there is no #, the Element id is one defined in the base specification.
048   */
049  ELEMENT,
050  /**
051   * The context is a particular extension from a particular StructureDefinition,
052   * and the expression is just a uri that identifies the extension.
053   */
054  EXTENSION,
055  /**
056   * added to help the parsers
057   */
058  NULL;
059
060  public static ExtensionContextType fromCode(String codeString) throws FHIRException {
061    if (codeString == null || "".equals(codeString))
062      return null;
063    if ("fhirpath".equals(codeString))
064      return FHIRPATH;
065    if ("element".equals(codeString))
066      return ELEMENT;
067    if ("extension".equals(codeString))
068      return EXTENSION;
069    throw new FHIRException("Unknown ExtensionContextType code '" + codeString + "'");
070  }
071
072  public String toCode() {
073    switch (this) {
074    case FHIRPATH:
075      return "fhirpath";
076    case ELEMENT:
077      return "element";
078    case EXTENSION:
079      return "extension";
080    case NULL:
081      return null;
082    default:
083      return "?";
084    }
085  }
086
087  public String getSystem() {
088    return "http://hl7.org/fhir/extension-context-type";
089  }
090
091  public String getDefinition() {
092    switch (this) {
093    case FHIRPATH:
094      return "The context is all elements that match the FHIRPath query found in the expression.";
095    case ELEMENT:
096      return "The context is any element that has an ElementDefinition.id that matches that found in the expression. This includes ElementDefinition Ids that have slicing identifiers. The full path for the element is [url]#[elementid]. If there is no #, the Element id is one defined in the base specification.";
097    case EXTENSION:
098      return "The context is a particular extension from a particular StructureDefinition, and the expression is just a uri that identifies the extension.";
099    case NULL:
100      return null;
101    default:
102      return "?";
103    }
104  }
105
106  public String getDisplay() {
107    switch (this) {
108    case FHIRPATH:
109      return "FHIRPath";
110    case ELEMENT:
111      return "Element ID";
112    case EXTENSION:
113      return "Extension URL";
114    case NULL:
115      return null;
116    default:
117      return "?";
118    }
119  }
120
121}