/**
*/
package org.archstudio.xadl3.structure_3_0;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import org.eclipse.emf.common.util.Enumerator;
/**
* <!-- begin-user-doc --> A representation of the literals of the enumeration '<em><b>Direction</b></em>', and utility
* methods for working with them. <!-- end-user-doc --> <!-- begin-model-doc --> This enumeration defines legal
* interface directions. They are: - none: No directionality selected or implied. - in: Incoming interface. Provided
* services should be "in" interfaces. - out: Outgoing interface. Required services should be "out" interfaces. - inout:
* Incoming AND outgoing interface. Endpoint both provides and requires a service. <!-- end-model-doc -->
*
* @see org.archstudio.xadl3.structure_3_0.Structure_3_0Package#getDirection()
* @model extendedMetaData="name='Direction'"
* @generated
*/
public enum Direction implements Enumerator {
/**
* The '<em><b>None</b></em>' literal object. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @see #NONE_VALUE
* @generated
* @ordered
*/
NONE(0, "none", "none"),
/**
* The '<em><b>In</b></em>' literal object. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @see #IN_VALUE
* @generated
* @ordered
*/
IN(1, "in", "in"),
/**
* The '<em><b>Out</b></em>' literal object. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @see #OUT_VALUE
* @generated
* @ordered
*/
OUT(2, "out", "out"),
/**
* The '<em><b>Inout</b></em>' literal object. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @see #INOUT_VALUE
* @generated
* @ordered
*/
INOUT(3, "inout", "inout");
/**
* The '<em><b>None</b></em>' literal value. <!-- begin-user-doc -->
* <p>
* If the meaning of '<em><b>None</b></em>' literal object isn't clear, there really should be more of a description
* here...
* </p>
* <!-- end-user-doc -->
*
* @see #NONE
* @model name="none"
* @generated
* @ordered
*/
public static final int NONE_VALUE = 0;
/**
* The '<em><b>In</b></em>' literal value. <!-- begin-user-doc -->
* <p>
* If the meaning of '<em><b>In</b></em>' literal object isn't clear, there really should be more of a description
* here...
* </p>
* <!-- end-user-doc -->
*
* @see #IN
* @model name="in"
* @generated
* @ordered
*/
public static final int IN_VALUE = 1;
/**
* The '<em><b>Out</b></em>' literal value. <!-- begin-user-doc -->
* <p>
* If the meaning of '<em><b>Out</b></em>' literal object isn't clear, there really should be more of a description
* here...
* </p>
* <!-- end-user-doc -->
*
* @see #OUT
* @model name="out"
* @generated
* @ordered
*/
public static final int OUT_VALUE = 2;
/**
* The '<em><b>Inout</b></em>' literal value. <!-- begin-user-doc -->
* <p>
* If the meaning of '<em><b>Inout</b></em>' literal object isn't clear, there really should be more of a
* description here...
* </p>
* <!-- end-user-doc -->
*
* @see #INOUT
* @model name="inout"
* @generated
* @ordered
*/
public static final int INOUT_VALUE = 3;
/**
* An array of all the '<em><b>Direction</b></em>' enumerators. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
private static final Direction[] VALUES_ARRAY = new Direction[] { NONE, IN, OUT, INOUT, };
/**
* A public read-only list of all the '<em><b>Direction</b></em>' enumerators. <!-- begin-user-doc --> <!--
* end-user-doc -->
*
* @generated
*/
public static final List<Direction> VALUES = Collections.unmodifiableList(Arrays.asList(VALUES_ARRAY));
/**
* Returns the '<em><b>Direction</b></em>' literal with the specified literal value. <!-- begin-user-doc --> <!--
* end-user-doc -->
*
* @param literal the literal.
* @return the matching enumerator or <code>null</code>.
* @generated
*/
public static Direction get(String literal) {
for (Direction result : VALUES_ARRAY) {
if (result.toString().equals(literal)) {
return result;
}
}
return null;
}
/**
* Returns the '<em><b>Direction</b></em>' literal with the specified name. <!-- begin-user-doc --> <!--
* end-user-doc -->
*
* @param name the name.
* @return the matching enumerator or <code>null</code>.
* @generated
*/
public static Direction getByName(String name) {
for (Direction result : VALUES_ARRAY) {
if (result.getName().equals(name)) {
return result;
}
}
return null;
}
/**
* Returns the '<em><b>Direction</b></em>' literal with the specified integer value. <!-- begin-user-doc --> <!--
* end-user-doc -->
*
* @param value the integer value.
* @return the matching enumerator or <code>null</code>.
* @generated
*/
public static Direction get(int value) {
switch (value) {
case NONE_VALUE:
return NONE;
case IN_VALUE:
return IN;
case OUT_VALUE:
return OUT;
case INOUT_VALUE:
return INOUT;
}
return null;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
private final int value;
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
private final String name;
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
private final String literal;
/**
* Only this class can construct instances. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
private Direction(int value, String name, String literal) {
this.value = value;
this.name = name;
this.literal = literal;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
@Override
public int getValue() {
return value;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getName() {
return name;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getLiteral() {
return literal;
}
/**
* Returns the literal value of the enumerator, which is its string representation. <!-- begin-user-doc --> <!--
* end-user-doc -->
*
* @generated
*/
@Override
public String toString() {
return literal;
}
} // Direction