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 V3CompressionAlgorithm {
038
039        /**
040         * bzip-2 compression format. See [http://www.bzip.org/] for more information.
041         */
042        BZ, 
043        /**
044         * The deflate compressed data format as specified in RFC 1951 [http://www.ietf.org/rfc/rfc1951.txt].
045         */
046        DF, 
047        /**
048         * A compressed data format that is compatible with the widely used GZIP utility as specified in RFC 1952 [http://www.ietf.org/rfc/rfc1952.txt] (uses the deflate algorithm).
049         */
050        GZ, 
051        /**
052         * Original UNIX compress algorithm and file format using the LZC algorithm (a variant of LZW).  Patent encumbered and less efficient than deflate.
053         */
054        Z, 
055        /**
056         * 7z compression file format. See [http://www.7-zip.org/7z.html] for more information.
057         */
058        Z7, 
059        /**
060         * A compressed data format that also uses the deflate algorithm.  Specified as RFC 1950 [http://www.ietf.org/rfc/rfc1952.txt]
061         */
062        ZL, 
063        /**
064         * added to help the parsers
065         */
066        NULL;
067        public static V3CompressionAlgorithm fromCode(String codeString) throws FHIRException {
068            if (codeString == null || "".equals(codeString))
069                return null;
070        if ("BZ".equals(codeString))
071          return BZ;
072        if ("DF".equals(codeString))
073          return DF;
074        if ("GZ".equals(codeString))
075          return GZ;
076        if ("Z".equals(codeString))
077          return Z;
078        if ("Z7".equals(codeString))
079          return Z7;
080        if ("ZL".equals(codeString))
081          return ZL;
082        throw new FHIRException("Unknown V3CompressionAlgorithm code '"+codeString+"'");
083        }
084        public String toCode() {
085          switch (this) {
086            case BZ: return "BZ";
087            case DF: return "DF";
088            case GZ: return "GZ";
089            case Z: return "Z";
090            case Z7: return "Z7";
091            case ZL: return "ZL";
092            default: return "?";
093          }
094        }
095        public String getSystem() {
096          return "http://hl7.org/fhir/v3/CompressionAlgorithm";
097        }
098        public String getDefinition() {
099          switch (this) {
100            case BZ: return "bzip-2 compression format. See [http://www.bzip.org/] for more information.";
101            case DF: return "The deflate compressed data format as specified in RFC 1951 [http://www.ietf.org/rfc/rfc1951.txt].";
102            case GZ: return "A compressed data format that is compatible with the widely used GZIP utility as specified in RFC 1952 [http://www.ietf.org/rfc/rfc1952.txt] (uses the deflate algorithm).";
103            case Z: return "Original UNIX compress algorithm and file format using the LZC algorithm (a variant of LZW).  Patent encumbered and less efficient than deflate.";
104            case Z7: return "7z compression file format. See [http://www.7-zip.org/7z.html] for more information.";
105            case ZL: return "A compressed data format that also uses the deflate algorithm.  Specified as RFC 1950 [http://www.ietf.org/rfc/rfc1952.txt]";
106            default: return "?";
107          }
108        }
109        public String getDisplay() {
110          switch (this) {
111            case BZ: return "bzip";
112            case DF: return "deflate";
113            case GZ: return "gzip";
114            case Z: return "compress";
115            case Z7: return "Z7";
116            case ZL: return "zlib";
117            default: return "?";
118          }
119    }
120
121
122}
123