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 Sun, May 6, 2018 17:51-0400 for FHIR v3.4.0
033
034
035import org.hl7.fhir.exceptions.FHIRException;
036
037public enum V3EntityNamePartType {
038
039        /**
040         * A delimiter has no meaning other than being literally printed in this name representation.  A delimiter has no implicit leading and trailing white space.
041         */
042        DEL, 
043        /**
044         * Family name, this is the name that links to the genealogy. In some cultures (e.g. Eritrea) the family name of a son is the first name of his father.
045         */
046        FAM, 
047        /**
048         * Given name (don't call it "first name" since this given names do not always come first)
049         */
050        GIV, 
051        /**
052         * A prefix has a strong association to the immediately following name part. A prefix has no implicit trailing white space (it has implicit leading white space though). Note that prefixes can be inverted.
053         */
054        PFX, 
055        /**
056         * Description:A suffix has a strong association to the immediately preceding name part. A suffix has no implicit leading white space (it has implicit trailing white space though). Suffices cannot be inverted.
057         */
058        SFX, 
059        /**
060         * added to help the parsers
061         */
062        NULL;
063        public static V3EntityNamePartType fromCode(String codeString) throws FHIRException {
064            if (codeString == null || "".equals(codeString))
065                return null;
066        if ("DEL".equals(codeString))
067          return DEL;
068        if ("FAM".equals(codeString))
069          return FAM;
070        if ("GIV".equals(codeString))
071          return GIV;
072        if ("PFX".equals(codeString))
073          return PFX;
074        if ("SFX".equals(codeString))
075          return SFX;
076        throw new FHIRException("Unknown V3EntityNamePartType code '"+codeString+"'");
077        }
078        public String toCode() {
079          switch (this) {
080            case DEL: return "DEL";
081            case FAM: return "FAM";
082            case GIV: return "GIV";
083            case PFX: return "PFX";
084            case SFX: return "SFX";
085            default: return "?";
086          }
087        }
088        public String getSystem() {
089          return "http://hl7.org/fhir/v3/EntityNamePartType";
090        }
091        public String getDefinition() {
092          switch (this) {
093            case DEL: return "A delimiter has no meaning other than being literally printed in this name representation.  A delimiter has no implicit leading and trailing white space.";
094            case FAM: return "Family name, this is the name that links to the genealogy. In some cultures (e.g. Eritrea) the family name of a son is the first name of his father.";
095            case GIV: return "Given name (don't call it \"first name\" since this given names do not always come first)";
096            case PFX: return "A prefix has a strong association to the immediately following name part. A prefix has no implicit trailing white space (it has implicit leading white space though). Note that prefixes can be inverted.";
097            case SFX: return "Description:A suffix has a strong association to the immediately preceding name part. A suffix has no implicit leading white space (it has implicit trailing white space though). Suffices cannot be inverted.";
098            default: return "?";
099          }
100        }
101        public String getDisplay() {
102          switch (this) {
103            case DEL: return "delimiter";
104            case FAM: return "family";
105            case GIV: return "given";
106            case PFX: return "prefix";
107            case SFX: return "suffix";
108            default: return "?";
109          }
110    }
111
112
113}
114