/* Copyright (c) 2010, skobbler GmbH
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. Neither the name of the project nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
package org.openstreetmap.josm.plugins.mapdust.service.value;
import java.io.Serializable;
import java.util.HashMap;
/**
* Defines the attributes of the <code>Status</code> object.
*
* @author Bea
*/
public class Status implements Serializable {
/** The serial version UID */
private static final long serialVersionUID = 5534551701260061940L;
/** The key of the <code>Status</code> */
private Integer key;
/** The value of the <code>Status</code> */
private String value;
/** The hash map containing the valid values */
private static java.util.HashMap<Integer, Status> table = null;
/**
* Builds a new <code>Status</code> object
*/
public Status() {}
/**
* Builds a new <code>status</code> object
*
* @param key The key of the object
* @param value The value of the object
*/
public Status(Integer key, String value) {
this.key = key;
this.value = value;
if (Status.table == null) {
Status.table = new HashMap<>();
}
Status.table.put(key, this);
}
/** The open status */
public static final Status OPEN = new Status(1, "Open");
/** The fixed status */
public static final Status FIXED = new Status(2, "Fixed");
/** The closed status */
public static final Status INVALID = new Status(3, "Invalid");
/**
* Returns the <code>Status</code> object for the given value.
*
* @param value The value of the object
* @return A <code>Status</code> object
* @throws java.lang.IllegalStateException If the status value is invalid
*/
public static Status getStatus(Integer value)
throws java.lang.IllegalStateException {
Status status = table.get(value);
if (status == null) {
throw new java.lang.IllegalStateException();
}
return status;
}
/**
* Verifies if two objects are equals or not.
*/
@Override
public boolean equals(java.lang.Object obj) {
return (obj == this);
}
/**
* Returns the hash code of the object
*/
@Override
public int hashCode() {
return toString().hashCode();
}
/**
* Returns the key
*
* @return the key
*/
public Integer getKey() {
return key;
}
/**
* Sets the key
*
* @return the value
*/
public String getValue() {
return value;
}
}