/* $Id: QedeqBoState.java,v 1.1 2005/06/17 17:10:09 m31 Exp $
 *
 * This file is part of the project "Hilbert II" - http://www.qedeq.org
 *
 * Copyright 2000-2005,  Michael Meyling <mime@qedeq.org>.
 *
 * "Hilbert II" is free software; you can redistribute
 * it and/or modify it under the terms of the GNU General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 */

package org.qedeq.kernel.bo.module;


/**
 * Represents a module state.
 *
 * @version $Revision: 1.1 $
 * @author      Michael Meyling
 */
public final class QedeqBoState {

    /** Creation phase. */
    public static final QedeqBoState STATE_CREATING
        = new QedeqBoState(ModuleConstants.STATE_STRING_CREATING,
            false, ModuleConstants.STATE_CODE_CREATING);

    /** Creation with errors. */
    public static final QedeqBoState STATE_CREATED_WITH_ERRORS
        = new QedeqBoState(ModuleConstants.STATE_STRING_CREATED_WITH_ERRORS,
            true, ModuleConstants.STATE_CODE_CREATED_WITH_ERRORS);

    /** Successfully created. */
    public static final QedeqBoState STATE_CREATED
        =  new QedeqBoState(ModuleConstants.STATE_STRING_CREATED,
            false, ModuleConstants.STATE_CODE_CREATED);

    /** Internal checking phase. */
    public static final QedeqBoState STATE_INTERNAL_CHECKING
        = new QedeqBoState(ModuleConstants.STATE_STRING_INTERNAL_CHECKING,
            false, ModuleConstants.STATE_CODE_INTERNAL_CHECKING);

    /** Internal check failed. */
    public static final QedeqBoState STATE_INTERNAL_CHECK_FAILED
        =  new QedeqBoState(ModuleConstants.STATE_STRING_INTERNAL_CHECK_FAILED,
            true, ModuleConstants.STATE_CODE_INTERNAL_CHECK_FAILED);

    /** Successfully internally checked. */
    public static final QedeqBoState STATE_INTERNALLY_CHECKED
        = new QedeqBoState(ModuleConstants.STATE_STRING_INTERNALLY_CHECKED,
            false, ModuleConstants.STATE_CODE_INTERNALLY_CHECKED);

    /** Complete checking phase. */
    public static final QedeqBoState STATE_COMPLETE_CHECKING
        = new QedeqBoState(ModuleConstants.STATE_STRING_COMPLETE_CHECKING,
            false, ModuleConstants.STATE_CODE_COMPLETE_CHECKING);

    /** Complete check failed. */
    public static final QedeqBoState STATE_CHECK_FAILED
        =  new QedeqBoState(ModuleConstants.STATE_STRING_COMPLETE_CHECK_FAILED,
            true, ModuleConstants.STATE_CODE_COMPLETE_CHECK_FAILED);

    /** Successfully completely checked. */
    public static final QedeqBoState STATE_CHECKED
        = new QedeqBoState(ModuleConstants.STATE_STRING_COMPLETELY_CHECKED,
            false, ModuleConstants.STATE_CODE_COMPLETELY_CHECKED);


    /** meaning of this state. */
    private final String text;

    /** is this state a failure? */
    private final boolean failure;

    /** Code for state. */
    private final int code;

    /**
     * Creates new module state.
     *
     * @param   text    meaning of this state, <code>null</code> is not permitted.
     * @param   failure is this a failure state?
     * @param   code    code of this state.
     * @throws  IllegalArgumentException    text == <code>null</code>
     */
    private QedeqBoState(final String text, final boolean failure, final int code) {
        this.text = text;
        if (this.text == null) {
            throw new IllegalArgumentException("text==null");
        }
        this.failure = failure;
        this.code = code;
    }

    /**
     * Get meaning of module state.
     *
     * @return  meaning of module state.
     */
    public final String getText() {
        return this.text;
    }

    /**
     * Is this a failure state?
     *
     * @return  is this a failure state?
     */
    public final boolean isFailure() {
        return this.failure;
    }

    /**
     * Get module state code.
     *
     * @return  Module state.
     */
    public final int getCode() {
        return this.code;
    }

    /*  (non-Javadoc)
     * @see java.lang.Object#toString()
     */
    public final String toString() {
        return this.text;
    }

    /*  (non-Javadoc)
     * @see java.lang.Object#hashCode()
     */
    public final int hashCode() {
        return this.text.hashCode();
    }

    /*  (non-Javadoc)
     * @see java.lang.Object#equals(java.lang.Object)
     */
    public final boolean equals(final Object obj) {
        if (obj == null || !(obj instanceof QedeqBoState)) {
            return false;
        }
        return text.equals(((QedeqBoState) obj).text);
    }

}
