mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			623 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			Java
		
	
	
	
			
		
		
	
	
			623 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			Java
		
	
	
	
/* DefaultTreeModel.java --
 | 
						|
   Copyright (C) 2002, 2004, 2005, 2006, Free Software Foundation, Inc.
 | 
						|
 | 
						|
This file is part of GNU Classpath.
 | 
						|
 | 
						|
GNU Classpath 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, or (at your option)
 | 
						|
any later version.
 | 
						|
 | 
						|
GNU Classpath 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.
 | 
						|
 | 
						|
You should have received a copy of the GNU General Public License
 | 
						|
along with GNU Classpath; see the file COPYING. If not, write to the
 | 
						|
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
 | 
						|
02110-1301 USA.
 | 
						|
 | 
						|
Linking this library statically or dynamically with other modules is
 | 
						|
making a combined work based on this library. Thus, the terms and
 | 
						|
conditions of the GNU General Public License cover the whole
 | 
						|
combination.
 | 
						|
 | 
						|
As a special exception, the copyright holders of this library give you
 | 
						|
permission to link this library with independent modules to produce an
 | 
						|
executable, regardless of the license terms of these independent
 | 
						|
modules, and to copy and distribute the resulting executable under
 | 
						|
terms of your choice, provided that you also meet, for each linked
 | 
						|
independent module, the terms and conditions of the license of that
 | 
						|
module. An independent module is a module which is not derived from
 | 
						|
or based on this library. If you modify this library, you may extend
 | 
						|
this exception to your version of the library, but you are not
 | 
						|
obligated to do so. If you do not wish to do so, delete this
 | 
						|
exception statement from your version. */
 | 
						|
 | 
						|
package javax.swing.tree;
 | 
						|
 | 
						|
import java.io.IOException;
 | 
						|
import java.io.ObjectInputStream;
 | 
						|
import java.io.ObjectOutputStream;
 | 
						|
import java.io.Serializable;
 | 
						|
import java.util.EventListener;
 | 
						|
 | 
						|
import javax.swing.event.EventListenerList;
 | 
						|
import javax.swing.event.TreeModelEvent;
 | 
						|
import javax.swing.event.TreeModelListener;
 | 
						|
 | 
						|
/**
 | 
						|
 * DefaultTreeModel
 | 
						|
 *
 | 
						|
 * @author Andrew Selkirk
 | 
						|
 */
 | 
						|
public class DefaultTreeModel
 | 
						|
    implements Serializable, TreeModel
 | 
						|
{
 | 
						|
  static final long serialVersionUID = -2621068368932566998L;
 | 
						|
 | 
						|
  /**
 | 
						|
   * root
 | 
						|
   */
 | 
						|
  protected TreeNode root;
 | 
						|
 | 
						|
  /**
 | 
						|
   * listenerList
 | 
						|
   */
 | 
						|
  protected EventListenerList listenerList = new EventListenerList();
 | 
						|
 | 
						|
  /**
 | 
						|
   * asksAllowsChildren
 | 
						|
   */
 | 
						|
  protected boolean asksAllowsChildren;
 | 
						|
 | 
						|
  /**
 | 
						|
   * Constructor DefaultTreeModel where any node can have children.
 | 
						|
   *
 | 
						|
   * @param root the tree root.
 | 
						|
   */
 | 
						|
  public DefaultTreeModel(TreeNode root)
 | 
						|
  {
 | 
						|
    this (root, false);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Create the DefaultTreeModel that may check if the nodes can have
 | 
						|
   * children or not.
 | 
						|
   *
 | 
						|
   * @param aRoot the tree root.
 | 
						|
   * @param asksAllowsChildren if true, each node is asked if it can have
 | 
						|
   * children. If false, the model does not care about this, supposing, that
 | 
						|
   * any node can have children.
 | 
						|
   */
 | 
						|
  public DefaultTreeModel(TreeNode aRoot, boolean asksAllowsChildren)
 | 
						|
  {
 | 
						|
    if (aRoot == null)
 | 
						|
      aRoot = new DefaultMutableTreeNode();
 | 
						|
    this.root = aRoot;
 | 
						|
    this.asksAllowsChildren = asksAllowsChildren;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * writeObject
 | 
						|
   *
 | 
						|
   * @param obj the object.
 | 
						|
   * @exception IOException TODO
 | 
						|
   */
 | 
						|
  private void writeObject(ObjectOutputStream obj) throws IOException
 | 
						|
  {
 | 
						|
    // TODO
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * readObject
 | 
						|
   *
 | 
						|
   * @param value0 TODO
 | 
						|
   * @exception IOException TODO
 | 
						|
   * @exception ClassNotFoundException TODO
 | 
						|
   */
 | 
						|
  private void readObject(ObjectInputStream value0) throws IOException,
 | 
						|
      ClassNotFoundException
 | 
						|
  {
 | 
						|
    // TODO
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * asksAllowsChildren
 | 
						|
   *
 | 
						|
   * @return boolean
 | 
						|
   */
 | 
						|
  public boolean asksAllowsChildren()
 | 
						|
  {
 | 
						|
    return asksAllowsChildren;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * setAsksAllowsChildren
 | 
						|
   *
 | 
						|
   * @param value TODO
 | 
						|
   */
 | 
						|
  public void setAsksAllowsChildren(boolean value)
 | 
						|
  {
 | 
						|
    asksAllowsChildren = value;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * setRoot
 | 
						|
   *
 | 
						|
   * @param root the root node.
 | 
						|
   */
 | 
						|
  public void setRoot(TreeNode root)
 | 
						|
  {
 | 
						|
    this.root = root;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * getRoot
 | 
						|
   *
 | 
						|
   * @return Object
 | 
						|
   */
 | 
						|
  public Object getRoot()
 | 
						|
  {
 | 
						|
    return root;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * getIndexOfChild
 | 
						|
   *
 | 
						|
   * @param parent TODO
 | 
						|
   * @param child TODO
 | 
						|
   * @return int
 | 
						|
   */
 | 
						|
  public int getIndexOfChild(Object parent, Object child)
 | 
						|
  {
 | 
						|
    for (int i = 0; i < getChildCount(parent); i++)
 | 
						|
      {
 | 
						|
        if (getChild(parent, i).equals(child))
 | 
						|
          return i;
 | 
						|
      }
 | 
						|
    return -1;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * getChild
 | 
						|
   *
 | 
						|
   * @param node TODO
 | 
						|
   * @param idx TODO
 | 
						|
   * @return Object
 | 
						|
   */
 | 
						|
  public Object getChild(Object node, int idx)
 | 
						|
  {
 | 
						|
    if (node instanceof TreeNode)
 | 
						|
      return ((TreeNode) node).getChildAt(idx);
 | 
						|
    else
 | 
						|
      return null;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * getChildCount
 | 
						|
   *
 | 
						|
   * @param node TODO
 | 
						|
   * @return int
 | 
						|
   */
 | 
						|
  public int getChildCount(Object node)
 | 
						|
  {
 | 
						|
    if (node instanceof TreeNode)
 | 
						|
      return ((TreeNode) node).getChildCount();
 | 
						|
    else
 | 
						|
      return 0;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Returns if the specified node is a leaf or not. When
 | 
						|
   * {@link #asksAllowsChildren} is true, then this checks if the TreeNode
 | 
						|
   * allows children, otherwise it returns the TreeNode's <code>leaf</code>
 | 
						|
   * property.
 | 
						|
   *
 | 
						|
   * @param node the node to check
 | 
						|
   *
 | 
						|
   * @return boolean <code>true</code> if the node is a leaf node,
 | 
						|
   *         <code>false</code> otherwise
 | 
						|
   *
 | 
						|
   * @throws ClassCastException if the specified node is not a
 | 
						|
   *         <code>TreeNode</code> instance
 | 
						|
   *
 | 
						|
   * @see TreeNode#getAllowsChildren()
 | 
						|
   * @see TreeNode#isLeaf()
 | 
						|
   */
 | 
						|
  public boolean isLeaf(Object node)
 | 
						|
  {
 | 
						|
    // The RI throws a ClassCastException when node isn't a TreeNode, so do we.
 | 
						|
    TreeNode treeNode = (TreeNode) node;
 | 
						|
    boolean leaf;
 | 
						|
    if (asksAllowsChildren)
 | 
						|
      leaf = ! treeNode.getAllowsChildren();
 | 
						|
    else
 | 
						|
      leaf = treeNode.isLeaf();
 | 
						|
    return leaf;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * <p>
 | 
						|
   * Invoke this method if you've modified the TreeNodes upon which this model
 | 
						|
   * depends. The model will notify all of its listeners that the model has
 | 
						|
   * changed. It will fire the events, necessary to update the layout caches and
 | 
						|
   * repaint the tree. The tree will <i>not</i> be properly refreshed if you
 | 
						|
   * call the JTree.repaint instead.
 | 
						|
   * </p>
 | 
						|
   * <p>
 | 
						|
   * This method will refresh the information about whole tree from the root. If
 | 
						|
   * only part of the tree should be refreshed, it is more effective to call
 | 
						|
   * {@link #reload(TreeNode)}.
 | 
						|
   * </p>
 | 
						|
   */
 | 
						|
  public void reload()
 | 
						|
  {
 | 
						|
    // Need to duplicate the code because the root can formally be
 | 
						|
    // no an instance of the TreeNode.
 | 
						|
    int n = getChildCount(root);
 | 
						|
    int[] childIdx = new int[n];
 | 
						|
    Object[] children = new Object[n];
 | 
						|
 | 
						|
    for (int i = 0; i < n; i++)
 | 
						|
      {
 | 
						|
        childIdx[i] = i;
 | 
						|
        children[i] = getChild(root, i);
 | 
						|
      }
 | 
						|
 | 
						|
    fireTreeStructureChanged(this, new Object[] { root }, childIdx, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoke this method if you've modified the TreeNodes upon which this model
 | 
						|
   * depends. The model will notify all of its listeners that the model has
 | 
						|
   * changed. It will fire the events, necessary to update the layout caches and
 | 
						|
   * repaint the tree. The tree will <i>not</i> be properly refreshed if you
 | 
						|
   * call the JTree.repaint instead.
 | 
						|
   *
 | 
						|
   * @param node - the tree node, from which the tree nodes have changed
 | 
						|
   *          (inclusive). If you do not know this node, call {@link #reload()}
 | 
						|
   *          instead.
 | 
						|
   */
 | 
						|
  public void reload(TreeNode node)
 | 
						|
  {
 | 
						|
    int n = getChildCount(node);
 | 
						|
    int[] childIdx = new int[n];
 | 
						|
    Object[] children = new Object[n];
 | 
						|
 | 
						|
    for (int i = 0; i < n; i++)
 | 
						|
      {
 | 
						|
        childIdx[i] = i;
 | 
						|
        children[i] = getChild(node, i);
 | 
						|
      }
 | 
						|
 | 
						|
    fireTreeStructureChanged(this, getPathToRoot(node), childIdx, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Messaged when the user has altered the value for the item
 | 
						|
   * identified by path to newValue. If newValue signifies a truly new
 | 
						|
   * value the model should post a treeNodesChanged event.
 | 
						|
   * This sets the user object of the TreeNode identified by
 | 
						|
   * path and posts a node changed. If you use custom user objects
 | 
						|
   * in the TreeModel you're going to need to subclass this and set
 | 
						|
   * the user object of the changed node to something meaningful.
 | 
						|
   *
 | 
						|
   * @param path - path to the node that the user has altered
 | 
						|
   * @param newValue - the new value from the TreeCellEditor
 | 
						|
   */
 | 
						|
  public void valueForPathChanged(TreePath path, Object newValue)
 | 
						|
  {
 | 
						|
    Object node = path.getLastPathComponent();
 | 
						|
    if (node instanceof MutableTreeNode)
 | 
						|
      {
 | 
						|
        ((MutableTreeNode) node).setUserObject(newValue);
 | 
						|
        int[] ci = null;
 | 
						|
        Object[] c = null;
 | 
						|
        Object[] parentPath = path.getPath();
 | 
						|
        if (path.getPathCount() > 1)
 | 
						|
          {
 | 
						|
            Object parent = ((TreeNode) node).getParent();
 | 
						|
            ci = new int[1];
 | 
						|
            ci[0] = getIndexOfChild(parent, node);
 | 
						|
            node = newValue;
 | 
						|
            path = path.getParentPath().pathByAddingChild(node);
 | 
						|
            c = new Object[1];
 | 
						|
            c[0] = node;
 | 
						|
            parentPath = path.getParentPath().getPath();
 | 
						|
          }
 | 
						|
 | 
						|
        fireTreeNodesChanged(this, parentPath, ci, c);
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoked this to insert newChild at location index in parents children.
 | 
						|
   * This will then message nodesWereInserted to create the appropriate event.
 | 
						|
   * This is the preferred way to add children as it will create the
 | 
						|
   * appropriate event.
 | 
						|
   *
 | 
						|
   * @param newChild is the node to add to the parent's children
 | 
						|
   * @param parent is the parent of the newChild
 | 
						|
   * @param index is the index of the newChild
 | 
						|
   */
 | 
						|
  public void insertNodeInto(MutableTreeNode newChild, MutableTreeNode parent,
 | 
						|
                             int index)
 | 
						|
  {
 | 
						|
    newChild.setParent(parent);
 | 
						|
    parent.insert(newChild, index);
 | 
						|
    int[] childIndices = new int[1];
 | 
						|
    childIndices[0] = index;
 | 
						|
    nodesWereInserted(parent, childIndices);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Message this to remove node from its parent. This will message
 | 
						|
   * nodesWereRemoved to create the appropriate event. This is the preferred
 | 
						|
   * way to remove a node as it handles the event creation for you.
 | 
						|
   *
 | 
						|
   * @param node to be removed
 | 
						|
   */
 | 
						|
  public void removeNodeFromParent(MutableTreeNode node)
 | 
						|
  {
 | 
						|
    TreeNode parent = node.getParent();
 | 
						|
    Object[] children = new Object[1];
 | 
						|
    children[0] = node;
 | 
						|
    int[] childIndices = new int[1];
 | 
						|
    childIndices[0] = getIndexOfChild(parent, node);
 | 
						|
    node.removeFromParent();
 | 
						|
    nodesWereRemoved(parent, childIndices, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoke this method after you've changed how node is to be represented
 | 
						|
   * in the tree.
 | 
						|
   *
 | 
						|
   * @param node that was changed
 | 
						|
   */
 | 
						|
  public void nodeChanged(TreeNode node)
 | 
						|
  {
 | 
						|
    TreeNode parent = node.getParent();
 | 
						|
    int[] childIndices = new int[1];
 | 
						|
    childIndices[0] = getIndexOfChild(parent, node);
 | 
						|
    Object[] children = new Object[1];
 | 
						|
    children[0] = node;
 | 
						|
    fireTreeNodesChanged(this, getPathToRoot(node), childIndices, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoke this method after you've inserted some TreeNodes
 | 
						|
   * into node. childIndices should be the index of the new elements and must
 | 
						|
   * be sorted in ascending order.
 | 
						|
   *
 | 
						|
   * @param parent that had a child added to
 | 
						|
   * @param childIndices of the children added
 | 
						|
   */
 | 
						|
  public void nodesWereInserted(TreeNode parent, int[] childIndices)
 | 
						|
  {
 | 
						|
    Object[] children = new Object[childIndices.length];
 | 
						|
    for (int i = 0; i < children.length; i++)
 | 
						|
      children[i] = getChild(parent, childIndices[i]);
 | 
						|
    fireTreeNodesInserted(this, getPathToRoot(parent), childIndices, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoke this method after you've removed some TreeNodes from node.
 | 
						|
   * childIndices should be the index of the removed elements and
 | 
						|
   * must be sorted in ascending order. And removedChildren should be the
 | 
						|
   * array of the children objects that were removed.
 | 
						|
   *
 | 
						|
   * @param parent that had a child added to
 | 
						|
   * @param childIndices of the children added
 | 
						|
   * @param removedChildren are all the children removed from parent.
 | 
						|
   */
 | 
						|
  public void nodesWereRemoved(TreeNode parent, int[] childIndices,
 | 
						|
                               Object[] removedChildren)
 | 
						|
  {
 | 
						|
    fireTreeNodesRemoved(this, getPathToRoot(parent), childIndices,
 | 
						|
                         removedChildren);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoke this method after you've changed how the children identified by
 | 
						|
   * childIndices are to be represented in the tree.
 | 
						|
   *
 | 
						|
   * @param node that is the parent of the children that changed in a tree.
 | 
						|
   * @param childIndices are the child nodes that changed.
 | 
						|
   */
 | 
						|
  public void nodesChanged(TreeNode node, int[] childIndices)
 | 
						|
  {
 | 
						|
    Object[] children = new Object[childIndices.length];
 | 
						|
    for (int i = 0; i < children.length; i++)
 | 
						|
      children[i] = getChild(node, childIndices[i]);
 | 
						|
    fireTreeNodesChanged(this, getPathToRoot(node), childIndices, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Invoke this method if you've totally changed the children of node and
 | 
						|
   * its childrens children. This will post a treeStructureChanged event.
 | 
						|
   *
 | 
						|
   * @param node that had its children and grandchildren changed.
 | 
						|
   */
 | 
						|
  public void nodeStructureChanged(TreeNode node)
 | 
						|
  {
 | 
						|
    int n = getChildCount(root);
 | 
						|
    int[] childIdx = new int[n];
 | 
						|
    Object[] children = new Object[n];
 | 
						|
 | 
						|
    for (int i = 0; i < n; i++)
 | 
						|
      {
 | 
						|
        childIdx[i] = i;
 | 
						|
        children[i] = getChild(root, i);
 | 
						|
      }
 | 
						|
 | 
						|
    fireTreeStructureChanged(this, new Object[] { root }, childIdx, children);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Builds the parents of node up to and including the root node, where
 | 
						|
   * the original node is the last element in the returned array. The
 | 
						|
   * length of the returned array gives the node's depth in the tree.
 | 
						|
   *
 | 
						|
   * @param node - the TreeNode to get the path for
 | 
						|
   * @return TreeNode[] - the path from node to the root
 | 
						|
   */
 | 
						|
  public TreeNode[] getPathToRoot(TreeNode node)
 | 
						|
  {
 | 
						|
    return getPathToRoot(node, 0);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Builds the parents of node up to and including the root node, where
 | 
						|
   * the original node is the last element in the returned array. The
 | 
						|
   * length of the returned array gives the node's depth in the tree.
 | 
						|
   *
 | 
						|
   * @param node - the TreeNode to get the path for
 | 
						|
   * @param depth - an int giving the number of steps already taken
 | 
						|
   * towards the root (on recursive calls), used to size the returned array
 | 
						|
   * @return an array of TreeNodes giving the path from the root to the
 | 
						|
   * specified node
 | 
						|
   */
 | 
						|
  protected TreeNode[] getPathToRoot(TreeNode node, int depth)
 | 
						|
  {
 | 
						|
    if (node == null)
 | 
						|
      {
 | 
						|
        if (depth == 0)
 | 
						|
          return null;
 | 
						|
 | 
						|
        return new TreeNode[depth];
 | 
						|
      }
 | 
						|
 | 
						|
    TreeNode[] path = getPathToRoot(node.getParent(), depth + 1);
 | 
						|
    path[path.length - depth - 1] = node;
 | 
						|
    return path;
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Registers a listere to the model.
 | 
						|
   *
 | 
						|
   * @param listener the listener to add
 | 
						|
   */
 | 
						|
  public void addTreeModelListener(TreeModelListener listener)
 | 
						|
  {
 | 
						|
    listenerList.add(TreeModelListener.class, listener);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Removes a listener from the model.
 | 
						|
   *
 | 
						|
   * @param listener the listener to remove
 | 
						|
   */
 | 
						|
  public void removeTreeModelListener(TreeModelListener listener)
 | 
						|
  {
 | 
						|
    listenerList.remove(TreeModelListener.class, listener);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Returns all registered <code>TreeModelListener</code> listeners.
 | 
						|
   *
 | 
						|
   * @return an array of listeners.
 | 
						|
   *
 | 
						|
   * @since 1.4
 | 
						|
   */
 | 
						|
  public TreeModelListener[] getTreeModelListeners()
 | 
						|
  {
 | 
						|
    return (TreeModelListener[]) listenerList
 | 
						|
        .getListeners(TreeModelListener.class);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Notifies all listeners that have registered interest for notification
 | 
						|
   * on this event type. The event instance is lazily created using the parameters
 | 
						|
   * passed into the fire method.
 | 
						|
   *
 | 
						|
   * @param source the node being changed
 | 
						|
   * @param path the path to the root node
 | 
						|
   * @param childIndices the indices of the changed elements
 | 
						|
   * @param children the changed elements
 | 
						|
   */
 | 
						|
  protected void fireTreeNodesChanged(Object source, Object[] path,
 | 
						|
      int[] childIndices, Object[] children)
 | 
						|
  {
 | 
						|
    TreeModelEvent event = new TreeModelEvent(source, path, childIndices,
 | 
						|
        children);
 | 
						|
 | 
						|
    TreeModelListener[] listeners = getTreeModelListeners();
 | 
						|
 | 
						|
    for (int i = listeners.length - 1; i >= 0; --i)
 | 
						|
      listeners[i].treeNodesChanged(event);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * fireTreeNodesInserted
 | 
						|
   *
 | 
						|
   * @param source the node where new nodes got inserted
 | 
						|
   * @param path the path to the root node
 | 
						|
   * @param childIndices the indices of the new elements
 | 
						|
   * @param children the new elements
 | 
						|
   */
 | 
						|
  protected void fireTreeNodesInserted(Object source, Object[] path,
 | 
						|
      int[] childIndices, Object[] children)
 | 
						|
  {
 | 
						|
    TreeModelEvent event = new TreeModelEvent(source, path, childIndices,
 | 
						|
        children);
 | 
						|
    TreeModelListener[] listeners = getTreeModelListeners();
 | 
						|
 | 
						|
    for (int i = listeners.length - 1; i >= 0; --i)
 | 
						|
      listeners[i].treeNodesInserted(event);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * fireTreeNodesRemoved
 | 
						|
   *
 | 
						|
   * @param source the node where nodes got removed-
 | 
						|
   * @param path the path to the root node
 | 
						|
   * @param childIndices the indices of the removed elements
 | 
						|
   * @param children the removed elements
 | 
						|
   */
 | 
						|
  protected void fireTreeNodesRemoved(Object source, Object[] path,
 | 
						|
      int[] childIndices, Object[] children)
 | 
						|
  {
 | 
						|
    TreeModelEvent event = new TreeModelEvent(source, path, childIndices,
 | 
						|
        children);
 | 
						|
    TreeModelListener[] listeners = getTreeModelListeners();
 | 
						|
 | 
						|
    for (int i = listeners.length - 1; i >= 0; --i)
 | 
						|
      listeners[i].treeNodesRemoved(event);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * fireTreeStructureChanged
 | 
						|
   *
 | 
						|
   * @param source the node where the model has changed
 | 
						|
   * @param path the path to the root node
 | 
						|
   * @param childIndices the indices of the affected elements
 | 
						|
   * @param children the affected elements
 | 
						|
   */
 | 
						|
  protected void fireTreeStructureChanged(Object source, Object[] path,
 | 
						|
      int[] childIndices, Object[] children)
 | 
						|
  {
 | 
						|
    TreeModelEvent event = new TreeModelEvent(source, path, childIndices,
 | 
						|
        children);
 | 
						|
    TreeModelListener[] listeners = getTreeModelListeners();
 | 
						|
 | 
						|
    for (int i = listeners.length - 1; i >= 0; --i)
 | 
						|
      listeners[i].treeStructureChanged(event);
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Returns the registered listeners of a given type.
 | 
						|
   *
 | 
						|
   * @param listenerType the listener type to return
 | 
						|
   *
 | 
						|
   * @return an array of listeners
 | 
						|
   *
 | 
						|
   * @since 1.3
 | 
						|
   */
 | 
						|
  public <T extends EventListener> T[] getListeners(Class<T> listenerType)
 | 
						|
  {
 | 
						|
    return listenerList.getListeners(listenerType);
 | 
						|
  }
 | 
						|
}
 |