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 V3ActRelationshipSplit {
037
038  /**
039   * The pre-condition associated with the branch is evaluated once and if true
040   * the branch may be entered. All other exclusive branches compete with each
041   * other and only one will be selected. This implements a COND, IF and CASE
042   * conditionals, or "XOR-split." The order in which the branches are considered
043   * may be specified in the priorityNumber attribute.
044   */
045  E1,
046  /**
047   * A branch is selected as soon as the pre-condition associated with the branch
048   * evaluates to true. If the condition is false, the branch may be entered
049   * later, when the condition turns true. All other exclusive branches compete
050   * with each other and only one will be selected. Each waiting branch executes
051   * in parallel with the default join code wait (see below). The order in which
052   * the branches are considered may be specified in the
053   * Service_relationship.priority_nmb.
054   */
055  EW,
056  /**
057   * A branch is executed if its associated preconditions permit. If associated
058   * preconditions do not permit, the branch is dropped. Inclusive branches are
059   * not suppressed and do not suppress other branches.
060   */
061  I1,
062  /**
063   * A branch is executed as soon as its associated conditions permit. If the
064   * condition is false, the branch may be entered later, when the condition turns
065   * true. Inclusive branches are not suppressed and do not suppress other
066   * branches. Each waiting branch executes in parallel with the default join code
067   * wait (see below).
068   */
069  IW,
070  /**
071   * added to help the parsers
072   */
073  NULL;
074
075  public static V3ActRelationshipSplit fromCode(String codeString) throws FHIRException {
076    if (codeString == null || "".equals(codeString))
077      return null;
078    if ("E1".equals(codeString))
079      return E1;
080    if ("EW".equals(codeString))
081      return EW;
082    if ("I1".equals(codeString))
083      return I1;
084    if ("IW".equals(codeString))
085      return IW;
086    throw new FHIRException("Unknown V3ActRelationshipSplit code '" + codeString + "'");
087  }
088
089  public String toCode() {
090    switch (this) {
091    case E1:
092      return "E1";
093    case EW:
094      return "EW";
095    case I1:
096      return "I1";
097    case IW:
098      return "IW";
099    case NULL:
100      return null;
101    default:
102      return "?";
103    }
104  }
105
106  public String getSystem() {
107    return "http://terminology.hl7.org/CodeSystem/v3-ActRelationshipSplit";
108  }
109
110  public String getDefinition() {
111    switch (this) {
112    case E1:
113      return "The pre-condition associated with the branch is evaluated once and if true the branch may be entered. All other exclusive branches compete with each other and only one will be selected. This implements a COND, IF and CASE conditionals, or \"XOR-split.\" The order in which the branches are considered may be specified in the priorityNumber attribute.";
114    case EW:
115      return "A branch is selected as soon as the pre-condition associated with the branch evaluates to true.  If the condition is false, the branch may be entered later, when the condition turns true.  All other exclusive branches compete with each other and only one will be selected.  Each waiting branch executes in parallel with the default join code wait  (see below). The order in which the branches are considered may be specified in the Service_relationship.priority_nmb.";
116    case I1:
117      return "A branch is executed if its associated preconditions permit. If associated preconditions do not permit, the branch is dropped.  Inclusive branches are not suppressed and do not suppress other branches.";
118    case IW:
119      return "A branch is executed as soon as its associated conditions permit.  If the condition is false, the branch may be entered later, when the condition turns true.  Inclusive branches are not suppressed and do not suppress other branches.  Each waiting branch executes in parallel with the default join code wait  (see below).";
120    case NULL:
121      return null;
122    default:
123      return "?";
124    }
125  }
126
127  public String getDisplay() {
128    switch (this) {
129    case E1:
130      return "exclusive try once";
131    case EW:
132      return "exclusive wait";
133    case I1:
134      return "inclusive try once";
135    case IW:
136      return "inclusive wait";
137    case NULL:
138      return null;
139    default:
140      return "?";
141    }
142  }
143
144}