📄 treepath.java
字号:
/* TreePath.java -- Copyright (C) 2002 Free Software Foundation, Inc.This file is part of GNU Classpath.GNU Classpath is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe 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, butWITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNUGeneral Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU Classpath; see the file COPYING. If not, write to theFree Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA02111-1307 USA.Linking this library statically or dynamically with other modules ismaking a combined work based on this library. Thus, the terms andconditions of the GNU General Public License cover the wholecombination.As a special exception, the copyright holders of this library give youpermission to link this library with independent modules to produce anexecutable, regardless of the license terms of these independentmodules, and to copy and distribute the resulting executable underterms of your choice, provided that you also meet, for each linkedindependent module, the terms and conditions of the license of thatmodule. An independent module is a module which is not derived fromor based on this library. If you modify this library, you may extendthis exception to your version of the library, but you are notobligated to do so. If you do not wish to do so, delete thisexception statement from your version. */package javax.swing.tree;// Importsimport java.io.*;/** * TreePath * @author Andrew Selkirk */public class TreePath implements Serializable { //------------------------------------------------------------- // Variables -------------------------------------------------- //------------------------------------------------------------- /** * path */ private Object[] path = null; //------------------------------------------------------------- // Initialization --------------------------------------------- //------------------------------------------------------------- /** * Constructor TreePath * @param path TODO */ public TreePath(Object[] path) { // Create Path this.path = new Object[path.length]; System.arraycopy(path, 0, this.path, 0, path.length); } // TreePath() /** * Constructor TreePath * @param element TODO */ public TreePath(Object element) { // Create Path path = new Object[1]; path[0] = element; } // TreePath() /** * Constructor TreePath * @param path TODO * @param element TODO */ protected TreePath(TreePath path, Object element) { // Variables Object[] treepath; // Get Tree Path treepath = path.getPath(); // Create Tree Path this.path = new Object[treepath.length + 1]; System.arraycopy(treepath, 0, this.path, 0, treepath.length); this.path[treepath.length] = element; } // TreePath() /** * Constructor TreePath * @param path TODO * @param length TODO */ protected TreePath(Object[] path, int length) { // Create Path this.path = new Object[length]; System.arraycopy(path, 0, this.path, 0, length); } // TreePath() /** * Constructor TreePath */ protected TreePath() { path = new Object[0]; } // TreePath() //------------------------------------------------------------- // Methods ---------------------------------------------------- //------------------------------------------------------------- /** * hashCode * @returns int */ public int hashCode() { return getLastPathComponent().hashCode(); } // hashCode() /** * equals * @param object TODO * @returns boolean */ public boolean equals(Object object) { // Variables Object[] treepath; int index; // Check for TreePath if (object instanceof TreePath) { // Get Path Elements treepath = ((TreePath) object).getPath(); // Check length if (treepath.length != path.length) { return false; } // if // Check Elements for (index = 0; index < path.length; index++) { if (treepath[index] != path[index]) { return false; } // if } // for // Tree Path's are equals return true; } // if // Unequal return false; } // equals() /** * toString * @returns String */ public String toString() { return null; // TODO } // toString() /** * writeObject * @param value0 TODO * @exception IOException TODO */ private void writeObject(ObjectOutputStream value0) throws IOException { // TODO } // writeObject() /** * readObject * @param value0 TODO * @exception IOException TODO * @exception ClassNotFoundException TODO */ private void readObject(ObjectInputStream value0) throws IOException, ClassNotFoundException { // TODO } // readObject() /** * getPath * @returns Object[] */ public Object[] getPath() { return path; } // getPath() /** * getLastPathComponent * @returns Object */ public Object getLastPathComponent() { return path[path.length - 1]; } // getLastPathComponent() /** * getPathCount * @returns int */ public int getPathCount() { return path.length; } // getPathCount() /** * getPathComponent * @param position TODO * @returns Object */ public Object getPathComponent(int position) { return path[position]; } // getPathComponent() /** * isDescendant * @param path TODO * @returns boolean */ public boolean isDescendant(TreePath path) { // Variables Object[] treepath; int index; int index2; // Get Descendant path treepath = path.getPath(); // Locate Start Index index = 0; index2 = 0; while (treepath[index] != this.path[index2]) { index++; } // while // Verify Paths while (treepath[index] == this.path[index2]) { index++; index2++; } // while // Check for descendant if (index2 != this.path.length) { return false; } // if // Is Descendant return true; } // isDescendant() /** * pathByAddingChild * @param element TODO * @returns TreePath */ public TreePath pathByAddingChild(Object element) { return new TreePath(this, element); } // pathByAddingChild() /** * getParentPath * @returns TreePath */ public TreePath getParentPath() { return new TreePath(this.getPath(), path.length - 1); } // getParentPath()} // TreePath
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -