Logo
Distributed Genetic Programming Framework
print print

File org.jfree.ui.action.DowngradeActionMap.java

Here you can find all the information about the file org.jfree.ui.action.DowngradeActionMap.java. You may explore it here or download it onto your local disk.
/* ========================================================================
 * JCommon : a free general purpose class library for the Java(tm) platform
 * ========================================================================
 *
 * (C) Copyright 2000-2005, by Object Refinery Limited and Contributors.
 * 
 * Project Info:  http://www.jfree.org/jcommon/index.html
 *
 * This library is free software; you can redistribute it and/or modify it 
 * under the terms of the GNU Lesser General Public License as published by 
 * the Free Software Foundation; either version 2.1 of the License, or 
 * (at your option) any later version.
 *
 * This library 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 Lesser General Public 
 * License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, 
 * USA.  
 *
 * [Java is a trademark or registered trademark of Sun Microsystems, Inc. 
 * in the United States and other countries.]
 * 
 * -----------------------
 * DowngradeActionMap.java
 * -----------------------
 * (C)opyright 2003, by Thomas Morgner and Contributors.
 *
 * Original Author:  Thomas Morgner;
 * Contributor(s):   David Gilbert (for Object Refinery Limited);
 *
 * $Id: DowngradeActionMap.java,v 1.3 2005/10/18 13:22:13 mungady Exp $
 *
 * Changes 
 * -------
 * 28-Oct-2003 : Initial version
 * 07-Jun-2004 : Corrected source headers (DG);
 * 
 */


package org.jfree.ui.action;

import java.util.ArrayList;
import java.util.HashMap;

import javax.swing.Action;

/**
 * An actionmap, which is JDK 1.2.2 compatible.
 * <p>
 * This implementation does not implement the ActionMap interface of
 * JDK 1.3 or higher to maintain the compatibility with JDK 1.2 which
 * does not know this interface.
 * <p>
 * The usage is still the same.
 *
 * @author Thomas Morger
 */

public class DowngradeActionMap {

    /** A map containing the key to action mapping. */
    private final HashMap actionMap;
  
    /** A list containing the actionkeys in their order of addition. */
    private final ArrayList actionList;
  
    /** The parent of this action map. */
    private DowngradeActionMap parent;

    /**
     * Default Constructor. Creates a new empty map.
     */

    public DowngradeActionMap() {
        this.actionMap = new HashMap();
        this.actionList = new ArrayList();
    }

    /**
     * Sets this <code>ActionMap</code>'s parent.
     *
     * @param map  the <code>ActionMap</code> that is the parent of this one
     */

    public void setParent(final DowngradeActionMap map) {
        this.parent = map;
    }

    /**
     * Returns this <code>ActionMap</code>'s parent.
     *
     * @return the <code>ActionMap</code> that is the parent of this one,
     *         or null if this <code>ActionMap</code> has no parent
     */

    public DowngradeActionMap getParent() {
        return this.parent;
    }

    /**
     * Adds a binding for <code>key</code> to <code>action</code>.
     * If <code>action</code> is null, this removes the current binding
     * for <code>key</code>.
     * <p>In most instances, <code>key</code> will be
     * <code>action.getValue(NAME)</code>.
     *
     * @param key the key for the action.
     * @param action the action to be added.
     */

    public void put(final Object key, final Action action) {
        if (action == null) {
            remove(key);
        }
        else {
           if (this.actionMap.containsKey(key)) {
               remove(key);
           }
           this.actionMap.put(key, action);
           this.actionList.add (key);
        }
    }

    /**
     * Returns the binding for <code>key</code>, messaging the
     * parent <code>ActionMap</code> if the binding is not locally defined.
     *
     * @param key the key to be queried.
     * @return the action for this key, or null if there is no such action.
     */

    public Action get(final Object key) {
        final Action retval = (Action) this.actionMap.get(key);
        if (retval != null) {
            return retval;
        }
        if (this.parent != null) {
            return this.parent.get(key);
        }
        return null;
    }

    /**
     * Removes the binding for <code>key</code> from this <code>ActionMap</code>.
     *
     * @param key the key to be removed.
     */

    public void remove(final Object key) {
        this.actionMap.remove(key);
        this.actionList.remove(key);
    }

    /**
     * Removes all the mappings from this <code>ActionMap</code>.
     */

    public void clear() {
        this.actionMap.clear();
        this.actionList.clear();
    }

    /**
     * Returns the <code>Action</code> names that are bound in this <code>ActionMap</code>.
     *
     * @return the keys which are directly bound to this map.
     */

    public Object[] keys() {
        return this.actionList.toArray();
    }

    /**
     * Returns the number of bindings.
     *
     * @return the number of entries in this map.
     */

    public int size() {
        return this.actionMap.size();
    }

    /**
     * Returns an array of the keys defined in this <code>ActionMap</code> and
     * its parent. This method differs from <code>keys()</code> in that
     * this method includes the keys defined in the parent.
     *
     * @return all keys of this map and all parents.
     */

    public Object[] allKeys() {
        if (this.parent == null) {
            return keys();
        }
        final Object[] parentKeys = this.parent.allKeys();
        final Object[] key = keys();
        final Object[] retval = new Object[parentKeys.length + key.length];
        System.arraycopy(key, 0, retval, 0, key.length);
        System.arraycopy(retval, 0, retval, key.length, retval.length);
        return retval;
    }

}

File Information:

file name:DowngradeActionMap.java
package:org.jfree.ui.action
qualified name:org.jfree.ui.action.DowngradeActionMap.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/jfree/ui/action/DowngradeActionMap.java
size:6.089 KB (6236 B)
uploaded: 2018-01-07 12:03:36 GMT+0000
last update: 2006-09-26 10:30:36 GMT+0000
last access: 2018-04-23 23:19:21 GMT+0000

statistics online since 2006-01-02.   RSS Feed
Contact us by sending an email to tweise@gmx.de to receive further information, to report errors, or to join our project.
All content on this site (http://dgpf.sourceforge.net/) is LGPL-licensed.
http://dgpf.sourceforge.net/scripts/source/source.php last modified at 2018-01-07 12:03:34 GMT+0000 served at 2018-04-23 23:19:21 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo