|
What this is
Other links
The source code
// $Id: NotationNameImpl.java,v 1.19 2004/10/02 13:29:42 mvw Exp $
// Copyright (c) 1996-2001 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.application.notation;
import org.apache.log4j.Logger;
import org.argouml.application.api.*;
import org.argouml.application.events.*;
import java.util.*;
import javax.swing.*;
/**
* This class provides definition and manipulation of notation names.
* All notation names will be accessed using the
* {@link NotationName} wrapper.
*
* Not mutable!
*
* @author Thierry Lach
* @since 0.9.4
*/
public class NotationNameImpl
implements NotationName, ArgoModuleEventListener
{
/** logger */
private static final Logger LOG = Logger.getLogger(NotationNameImpl.class);
private String name = null;
private String version = null;
private Icon icon = null;
private static ArrayList notations = new ArrayList();
/** A notation without a version or icon.
*
* @param theName the name of the notation
*/
protected NotationNameImpl(String theName) {
this(theName, null, null);
}
/** A notation without a version and with an icon.
*
* @param theName the name of the notation
* @param theIcon the icon for of the notation
*/
protected NotationNameImpl(String theName, Icon theIcon) {
this(theName, null, theIcon);
}
/** A notation with a version and no icon.
*
* @param theName the name of the notation
* @param theVersion the version of the notation
*/
protected NotationNameImpl(String theName, String theVersion) {
this(theName, theVersion, null);
}
/** A notation with a version and an icon.
*
* @param myName the name of the notation
* @param myVersion the version of the notation
* @param myIcon the icon of the notation
*/
protected NotationNameImpl(String myName, String myVersion, Icon myIcon) {
name = myName;
version = myVersion;
icon = myIcon;
}
/** Accessor for the language name
*
* @see org.argouml.application.api.NotationName#getName()
*/
public String getName() {
return name;
}
/** Accessor for the language version
*
* @see org.argouml.application.api.NotationName#getVersion()
*/
public String getVersion() {
return version;
}
/** Gets a textual title for the notation suitable for use
* in a combo box or other such visual location.
*
* @see org.argouml.application.api.NotationName#getTitle()
*/
public String getTitle() {
String myName = name;
if (myName.equalsIgnoreCase("uml")) {
myName = myName.toUpperCase();
}
if (version == null || version.equals("")) {
return myName;
}
else {
return myName + " " + version;
}
}
/** Returns an icon for the notation, or null if no icon is available.
*
* @see org.argouml.application.api.NotationName#getIcon()
*/
public Icon getIcon() {
return icon;
}
/**
* @see org.argouml.application.api.NotationName#getConfigurationValue()
*/
public String getConfigurationValue() {
return getNotationNameString(name, version);
}
/**
* @see java.lang.Object#toString()
*/
public String toString() {
return getTitle();
}
/*public String toString() {
if (_version == null) return "{NotationNameImpl:" + _name + "}";
return "{NotationNameImpl:" + _name + " version " + _version + "}";
}*/
/**
* @param k1 first part of the given name
* @param k2 2nd part of the given name
* @return the notation name string
*/
public static String getNotationNameString(String k1, String k2) {
if (k2 == null) return k1;
if (k2.equals("")) return k1;
return k1 + "." + k2;
}
private static void fireEvent(int eventType, NotationName nn) {
ArgoEventPump.fireEvent(new ArgoNotationEvent(eventType, nn));
}
/**
* Create a NotationName with or without a version.
* The NotationName is only created if there is no such notation before.
*
* @param k1 the 1st part of the notation name
* @param k2 the 2nd part of the notation name
* @param icon the icon for the notation
* @return the newly created or the old NotationName
*/
public static NotationName makeNotation(String k1, String k2, Icon icon) {
NotationName nn = null;
nn = findNotation(getNotationNameString(k1, k2));
if (nn == null) {
nn = (NotationName) new NotationNameImpl(k1, k2, icon);
notations.add(nn);
fireEvent(ArgoEventTypes.NOTATION_ADDED, nn);
}
return nn;
}
/** Get all of the registered notations.
*
* @return an ArrayList with all notations
*/
public static ArrayList getAvailableNotations() {
return notations;
}
/** Finds a NotationName matching the configuration string.
* Returns null if no match.
*
* @param s the configuration string
* @return the name of the notation or null
*/
public static NotationName findNotation(String s) {
ListIterator iterator = notations.listIterator();
while (iterator.hasNext()) {
try {
NotationName nn = (NotationName) iterator.next();
if (s.equals(nn.getConfigurationValue())) {
return nn;
}
}
catch (Exception e) {
LOG.error ("Unexpected exception", e);
}
}
return null;
}
/**
* @see org.argouml.application.api.NotationName#equals(org.argouml.application.api.NotationName)
*/
public boolean equals(NotationName nn) {
return this.getConfigurationValue().equals(nn.getConfigurationValue());
}
/** Finds a NotationName matching the language with no version.
* Returns null if no match.
*
* @param k1 the notation name string
* @return the notation name
*/
public static NotationName getNotation(String k1) {
return findNotation(getNotationNameString(k1, null));
}
/**
* Finds a NotationName matching the language and version.
* Returns null if no match.
*
* @param k1 the 1st part of the notation name
* @param k2 the 2nd part of the notation name
* @return the notation name
*/
public static NotationName getNotation(String k1, String k2) {
return findNotation(getNotationNameString(k1, k2));
}
/**
* @see org.argouml.application.events.ArgoModuleEventListener#moduleLoaded(org.argouml.application.events.ArgoModuleEvent)
*/
public void moduleLoaded(ArgoModuleEvent event) {
LOG.info ("notation.moduleLoaded(" + event + ")");
}
/**
* @see org.argouml.application.events.ArgoModuleEventListener#moduleUnloaded(org.argouml.application.events.ArgoModuleEvent)
*/
public void moduleUnloaded(ArgoModuleEvent event) {
}
/**
* @see org.argouml.application.events.ArgoModuleEventListener#moduleEnabled(org.argouml.application.events.ArgoModuleEvent)
*/
public void moduleEnabled(ArgoModuleEvent event) {
}
/**
* @see org.argouml.application.events.ArgoModuleEventListener#moduleDisabled(org.argouml.application.events.ArgoModuleEvent)
*/
public void moduleDisabled(ArgoModuleEvent event) {
}
}
|
Copyright 1998-2008 Alvin Alexander
All Rights Reserved.
devdaily.com is based in louisville, kentucky, and this web site is hosted by godaddy.com