/* DefaultTreeModel.java -- Copyright (C) 2002, 2004 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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 = null; /** * listenerList */ protected EventListenerList listenerList = new EventListenerList(); /** * asksAllowsChildren */ protected boolean asksAllowsChildren; /** * Constructor DefaultTreeModel * @param value0 TODO */ public DefaultTreeModel(TreeNode root) { setRoot(root); } /** * Constructor DefaultTreeModel * @param value0 TODO * @param value1 TODO */ public DefaultTreeModel(TreeNode root, boolean asksAllowsChildren) { setRoot(root); this.asksAllowsChildren = asksAllowsChildren; } /** * writeObject * @param value0 TODO * @exception IOException TODO */ private void writeObject(ObjectOutputStream value0) 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 value0 TODO */ public void setAsksAllowsChildren(boolean value) { asksAllowsChildren = value; // TODO } /** * setRoot * @param value0 TODO */ public void setRoot(TreeNode root) { // Sanity Check if (root == null) { throw new IllegalArgumentException("null root"); } // Set new root this.root = root; // TODO } /** * getRoot * @return Object */ public Object getRoot() { return root; } /** * getIndexOfChild * @param value0 TODO * @param value1 TODO * @return int */ public int getIndexOfChild(Object parent, Object child) { return 0; // TODO } /** * getChild * @param value0 TODO * @param value1 TODO * @return Object */ public Object getChild(Object node, int idx) { if (node instanceof TreeNode) return ((TreeNode)node).getChildAt(idx); else return null; } /** * getChildCount * @param value0 TODO * @return int */ public int getChildCount(Object node) { if (node instanceof TreeNode) return ((TreeNode)node).getChildCount(); else return 0; } /** * isLeaf * @param value0 TODO * @return boolean */ public boolean isLeaf(Object node) { if (node instanceof TreeNode) return ((TreeNode)node).isLeaf(); else return true; } /** * reload */ public void reload() { // TODO } /** * reload * @param value0 TODO */ public void reload(TreeNode value0) { // TODO } /** * valueForPathChanged * @param value0 TODO * @param value1 TODO */ public void valueForPathChanged(TreePath value0, Object value1) { // TODO } /** * insertNodeInto * @param value0 TODO * @param value1 TODO * @param value2 TODO */ public void insertNodeInto(MutableTreeNode value0, MutableTreeNode value1, int value2) { // TODO } /** * removeNodeFromParent * @param value0 TODO */ public void removeNodeFromParent(MutableTreeNode value0) { // TODO } /** * nodeChanged * @param value0 TODO */ public void nodeChanged(TreeNode value0) { // TODO } /** * nodesWereInserted * @param value0 TODO * @param value1 TODO */ public void nodesWereInserted(TreeNode value0, int[] value1) { // TODO } /** * nodesWereRemoved * @param value0 TODO * @param value1 TODO * @param value2 TODO */ public void nodesWereRemoved(TreeNode value0, int[] value1, Object[] value2) { // TODO } /** * nodesChanged * @param value0 TODO * @param value1 TODO */ public void nodesChanged(TreeNode value0, int[] value1) { // TODO } /** * nodeStructureChanged * @param value0 TODO */ public void nodeStructureChanged(TreeNode value0) { // TODO } /** * getPathToRoot * @param value0 TODO * @return TreeNode[] */ public TreeNode[] getPathToRoot(TreeNode value0) { return null; // TODO } /** * getPathToRoot * @param value0 TODO * @param value1 TODO * @return TreeNode[] */ protected TreeNode[] getPathToRoot(TreeNode value0, int value1) { return null; // TODO } /** * 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); } /** * fireTreeNodesChanged * * @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 EventListener[] getListeners(Class listenerType) { return listenerList.getListeners(listenerType); } }