// $Id: Decision.java 12950 2007-07-01 08:10:04Z tfmorris $ // Copyright (c) 1996-2006 The Regents of the University of California. All // Rights Reserved. Permission to use, copy, modify, and distribute this // software and its documentation without fee, and without a written // agreement is hereby granted, provided that the above copyright notice // and this paragraph appear in all copies. This software program and // documentation are copyrighted by The Regents of the University of // California. The software program and documentation are supplied "AS // IS", without any accompanying services from The Regents. The Regents // does not warrant that the operation of the program will be // uninterrupted or error-free. The end-user understands that the program // was developed for research purposes and is advised not to rely // exclusively on the program for any reason. IN NO EVENT SHALL THE // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, // UPDATES, ENHANCEMENTS, OR MODIFICATIONS. package org.argouml.cognitive; /** * Posters look at the design material from different view points, since they * have to make different decisions in their evaluation process. A decision is a * unit which describes what kind of decision a given poster supports. E.g. a * designer is interested in making particular decisions, whereas a critic can * support relevant information which help making a particular decision (aka a * decision which lies in the domain specified by this class). * */ public class Decision { //////////////////////////////////////////////////////////////// // constants /** * This is another test. */ public static final Decision UNSPEC = new Decision("misc.decision.uncategorized", 1); //////////////////////////////////////////////////////////////// // instance variables /** * The localized name. */ private String name; /** * The priority. */ private int priority; /** * The constructor. * * @param n * the (not yet localized) name * @param p * the priority */ public Decision(String n, int p) { name = Translator.localize(n); priority = p; } //////////////////////////////////////////////////////////////// // accessors /* * @see java.lang.Object#hashCode() */ @Override public int hashCode() { if (name == null) { return 0; } return name.hashCode(); } /** * Two decisions are considered to be equal if their names are equal. The * priority is not considered. * * {@inheritDoc} */ @Override public boolean equals(Object d2) { if (!(d2 instanceof Decision)) { return false; } return ((Decision) d2).getName().equals(getName()); } /** * @return the localized name */ public String getName() { return name; } /** * @param n * the localized name */ public void setName(String n) { name = n; } /** * @return the priority */ public int getPriority() { return priority; } /** * @param p * the priority */ public void setPriority(int p) { priority = p; } /* * @see java.lang.Object#toString() */ @Override public String toString() { return getName(); } }