package atlas.classifiers;
 
public class StatusClassifier 
    implements java.io.Serializable, iapp.services.Classifier {
 
    public static final StatusClassifier FORWARD = new StatusClassifier("FORWARD");
    public static final StatusClassifier BACKWARD = new StatusClassifier("BACKWARD");
    public static final StatusClassifier UPLOAD = new StatusClassifier("UPLOAD");
    public static final StatusClassifier DOWNLOAD = new StatusClassifier("DOWNLOAD");
    public static final StatusClassifier PROCESSED = new StatusClassifier("PROCESSED");
    public static final StatusClassifier PROCESSING = new StatusClassifier("PROCESSING");
    public static final StatusClassifier AGGREGATE = new StatusClassifier("AGGREGATE");
    public static final StatusClassifier DECRYPT = new StatusClassifier("DECRYPT");
    public static final StatusClassifier ENCRYPT = new StatusClassifier("ENCRYPT");
    public static final StatusClassifier ACCOUNT_UPDATE = new StatusClassifier("ACCOUNT_UPDATE");
    public static final StatusClassifier SPLIT = new StatusClassifier("SPLIT");
    public static final StatusClassifier FORWARD = new StatusClassifier("FORWARD");
    public static final StatusClassifier BACKWARD = new StatusClassifier("BACKWARD");
    public static final StatusClassifier UPLOAD = new StatusClassifier("UPLOAD");
    public static final StatusClassifier DOWNLOAD = new StatusClassifier("DOWNLOAD");
    public static final StatusClassifier PROCESSED = new StatusClassifier("PROCESSED");
    public static final StatusClassifier PROCESSING = new StatusClassifier("PROCESSING");
    public static final StatusClassifier AGGREGATE = new StatusClassifier("AGGREGATE");
    public static final StatusClassifier DECRYPT = new StatusClassifier("DECRYPT");
    public static final StatusClassifier ENCRYPT = new StatusClassifier("ENCRYPT");
    public static final StatusClassifier ACCOUNT_UPDATE = new StatusClassifier("ACCOUNT_UPDATE");
    public static final StatusClassifier SPLIT = new StatusClassifier("SPLIT");
    public static final StatusClassifier FORWARD = new StatusClassifier("FORWARD");
    public static final StatusClassifier BACKWARD = new StatusClassifier("BACKWARD");
    public static final StatusClassifier UPLOAD = new StatusClassifier("UPLOAD");
    public static final StatusClassifier DOWNLOAD = new StatusClassifier("DOWNLOAD");
    public static final StatusClassifier PROCESSED = new StatusClassifier("PROCESSED");
    public static final StatusClassifier PROCESSING = new StatusClassifier("PROCESSING");
    public static final StatusClassifier AGGREGATE = new StatusClassifier("AGGREGATE");
    public static final StatusClassifier DECRYPT = new StatusClassifier("DECRYPT");
    public static final StatusClassifier ENCRYPT = new StatusClassifier("ENCRYPT");
    public static final StatusClassifier ACCOUNT_UPDATE = new StatusClassifier("ACCOUNT_UPDATE");
    public static final StatusClassifier SPLIT = new StatusClassifier("SPLIT");
 
    private static final java.util.Map values = new java.util.TreeMap();
    private static java.util.List literals = new java.util.ArrayList(3);
    private static java.util.List names = new java.util.ArrayList(3);
 
    /**
     * Initializes the values.
     */
    static {
        values.put(FORWARD.value, FORWARD);
	literals.add(FORWARD.value);
	FORWARD.setName("FORWARD");
        names.add("FORWARD");
        values.put(BACKWARD.value, BACKWARD);
	literals.add(BACKWARD.value);
	BACKWARD.setName("BACKWARD");
        names.add("BACKWARD");
        values.put(UPLOAD.value, UPLOAD);
	literals.add(UPLOAD.value);
	UPLOAD.setName("UPLOAD");
        names.add("UPLOAD");
        values.put(DOWNLOAD.value, DOWNLOAD);
	literals.add(DOWNLOAD.value);
	DOWNLOAD.setName("DOWNLOAD");
        names.add("DOWNLOAD");
        values.put(PROCESSED.value, PROCESSED);
	literals.add(PROCESSED.value);
	PROCESSED.setName("PROCESSED");
        names.add("PROCESSED");
        values.put(PROCESSING.value, PROCESSING);
	literals.add(PROCESSING.value);
	PROCESSING.setName("PROCESSING");
        names.add("PROCESSING");
        values.put(AGGREGATE.value, AGGREGATE);
	literals.add(AGGREGATE.value);
	AGGREGATE.setName("AGGREGATE");
        names.add("AGGREGATE");
        values.put(DECRYPT.value, DECRYPT);
	literals.add(DECRYPT.value);
	DECRYPT.setName("DECRYPT");
        names.add("DECRYPT");
        values.put(ENCRYPT.value, ENCRYPT);
	literals.add(ENCRYPT.value);
	ENCRYPT.setName("ENCRYPT");
        names.add("ENCRYPT");
        values.put(ACCOUNT_UPDATE.value, ACCOUNT_UPDATE);
	literals.add(ACCOUNT_UPDATE.value);
	ACCOUNT_UPDATE.setName("ACCOUNT_UPDATE");
        names.add("ACCOUNT_UPDATE");
        values.put(SPLIT.value, SPLIT);
	literals.add(SPLIT.value);
	SPLIT.setName("SPLIT");
        names.add("SPLIT");
        values.put(FORWARD.value, FORWARD);
	literals.add(FORWARD.value);
	FORWARD.setName("FORWARD");
        names.add("FORWARD");
        values.put(BACKWARD.value, BACKWARD);
	literals.add(BACKWARD.value);
	BACKWARD.setName("BACKWARD");
        names.add("BACKWARD");
        values.put(UPLOAD.value, UPLOAD);
	literals.add(UPLOAD.value);
	UPLOAD.setName("UPLOAD");
        names.add("UPLOAD");
        values.put(DOWNLOAD.value, DOWNLOAD);
	literals.add(DOWNLOAD.value);
	DOWNLOAD.setName("DOWNLOAD");
        names.add("DOWNLOAD");
        values.put(PROCESSED.value, PROCESSED);
	literals.add(PROCESSED.value);
	PROCESSED.setName("PROCESSED");
        names.add("PROCESSED");
        values.put(PROCESSING.value, PROCESSING);
	literals.add(PROCESSING.value);
	PROCESSING.setName("PROCESSING");
        names.add("PROCESSING");
        values.put(AGGREGATE.value, AGGREGATE);
	literals.add(AGGREGATE.value);
	AGGREGATE.setName("AGGREGATE");
        names.add("AGGREGATE");
        values.put(DECRYPT.value, DECRYPT);
	literals.add(DECRYPT.value);
	DECRYPT.setName("DECRYPT");
        names.add("DECRYPT");
        values.put(ENCRYPT.value, ENCRYPT);
	literals.add(ENCRYPT.value);
	ENCRYPT.setName("ENCRYPT");
        names.add("ENCRYPT");
        values.put(ACCOUNT_UPDATE.value, ACCOUNT_UPDATE);
	literals.add(ACCOUNT_UPDATE.value);
	ACCOUNT_UPDATE.setName("ACCOUNT_UPDATE");
        names.add("ACCOUNT_UPDATE");
        values.put(SPLIT.value, SPLIT);
	literals.add(SPLIT.value);
	SPLIT.setName("SPLIT");
        names.add("SPLIT");
        values.put(FORWARD.value, FORWARD);
	literals.add(FORWARD.value);
	FORWARD.setName("FORWARD");
        names.add("FORWARD");
        values.put(BACKWARD.value, BACKWARD);
	literals.add(BACKWARD.value);
	BACKWARD.setName("BACKWARD");
        names.add("BACKWARD");
        values.put(UPLOAD.value, UPLOAD);
	literals.add(UPLOAD.value);
	UPLOAD.setName("UPLOAD");
        names.add("UPLOAD");
        values.put(DOWNLOAD.value, DOWNLOAD);
	literals.add(DOWNLOAD.value);
	DOWNLOAD.setName("DOWNLOAD");
        names.add("DOWNLOAD");
        values.put(PROCESSED.value, PROCESSED);
	literals.add(PROCESSED.value);
	PROCESSED.setName("PROCESSED");
        names.add("PROCESSED");
        values.put(PROCESSING.value, PROCESSING);
	literals.add(PROCESSING.value);
	PROCESSING.setName("PROCESSING");
        names.add("PROCESSING");
        values.put(AGGREGATE.value, AGGREGATE);
	literals.add(AGGREGATE.value);
	AGGREGATE.setName("AGGREGATE");
        names.add("AGGREGATE");
        values.put(DECRYPT.value, DECRYPT);
	literals.add(DECRYPT.value);
	DECRYPT.setName("DECRYPT");
        names.add("DECRYPT");
        values.put(ENCRYPT.value, ENCRYPT);
	literals.add(ENCRYPT.value);
	ENCRYPT.setName("ENCRYPT");
        names.add("ENCRYPT");
        values.put(ACCOUNT_UPDATE.value, ACCOUNT_UPDATE);
	literals.add(ACCOUNT_UPDATE.value);
	ACCOUNT_UPDATE.setName("ACCOUNT_UPDATE");
        names.add("ACCOUNT_UPDATE");
        values.put(SPLIT.value, SPLIT);
	literals.add(SPLIT.value);
	SPLIT.setName("SPLIT");
        names.add("SPLIT");
        literals = java.util.Collections.unmodifiableList(literals);
        names = java.util.Collections.unmodifiableList(names);
    }
 
	private java.lang.String value;
	private java.lang.String name;
 
	/**
     * The default constructor allowing super classes to access it.
     */
    protected StatusClassifier() {}
 
    private StatusClassifier(java.lang.String value) {
        this.value = value;
    }
 
	public String toString() {
        return java.lang.String.valueOf(value);
    }
 
    /**
     * Creates an instance of StatusClassifier from <code>value</code>.
     *
     * @param value the value to create the StatusClassifier from.
     */
    public static StatusClassifier fromString(java.lang.String value) {
        if(value == null) return null;
		final StatusClassifier typeValue = (StatusClassifier) values.get(value);
        if (typeValue == null) {
            throw new IllegalArgumentException("invalid value '" + value + "', possible values are: " + literals);
        }
        return typeValue;
    }
 
	/**
	* Checks correct value for the classifier
	*/
	public boolean isStatusClassifier(java.lang.String value){
	  return (value == null || values.get(value) != null);
	}
    /**
     * Get/set for value
     */
    public java.lang.String getValue() {
        return this.value;
    }
    public java.lang.String getName() {
        return this.name;
    }
    /**
     * Get/set for name
     */
    private void setName(java.lang.String name) {
        this.name = name;
    }
    /**
     * @see java.lang.Comparable#compareTo(java.lang.Object)
     */
    public int compareTo(Object that)
    {
        return (this == that) ? 0 : this.getValue().compareTo(((StatusClassifier)that).getValue());
    }
 
    public static java.util.Map getValues() {
        return values;
    }
 
    /**
     * Returns an unmodifiable list containing the literals that are known by this enumeration.
     *
     * @return A List containing the actual literals defined by this enumeration, this list
     *         can not be modified.
     */
    public static java.util.List literals() {
        return literals;
    }
 
    /**
     * Returns an unmodifiable list containing the names of the literals that are known
     * by this enumeration.
     *
     * @return A List containing the actual names of the literals defined by this
     *         enumeration, this list can not be modified.
     */
    public static java.util.List names() {
        return names;
    }
 
    /**
     * @see java.lang.Object#equals(java.lang.Object)
     */
    public boolean equals(Object object) {
        return (this == object)
            || (object instanceof StatusClassifier && ((StatusClassifier)object).getValue().equals(
                this.getValue()));
    }
 
    /**
     * @see java.lang.Object#hashCode()
     */
    public int hashCode() {
        return this.getValue().hashCode();
    }
 
    /**
     * This method allows the deserialization of an instance of this enumeration type to return the actual instance
     * that will be the singleton for the JVM in which the current thread is running.
     * <p/>
     * Doing this will allow users to safely use the equality operator <code>==</code> for enumerations because
     * a regular deserialized object is always a newly constructed instance and will therefore never be
     * an existing reference; it is this <code>readResolve()</code> method which will intercept the deserialization
     * process in order to return the proper singleton reference.
     */
    private java.lang.Object readResolve() throws java.io.ObjectStreamException {
        return StatusClassifier.fromString(this.value);
    }
 
}