2 Copyright (C) 2002 Free Software Foundation, Inc.
4 This file is part of GNU Classpath.
6 GNU Classpath is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
11 GNU Classpath is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU Classpath; see the file COPYING. If not, write to the
18 Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
21 Linking this library statically or dynamically with other modules is
22 making a combined work based on this library. Thus, the terms and
23 conditions of the GNU General Public License cover the whole
26 As a special exception, the copyright holders of this library give you
27 permission to link this library with independent modules to produce an
28 executable, regardless of the license terms of these independent
29 modules, and to copy and distribute the resulting executable under
30 terms of your choice, provided that you also meet, for each linked
31 independent module, the terms and conditions of the license of that
32 module. An independent module is a module which is not derived from
33 or based on this library. If you modify this library, you may extend
34 this exception to your version of the library, but you are not
35 obligated to do so. If you do not wish to do so, delete this
36 exception statement from your version. */
39 package javax
.swing
.tree
;
41 import java
.io
.IOException
;
42 import java
.io
.ObjectInputStream
;
43 import java
.io
.ObjectOutputStream
;
44 import java
.io
.Serializable
;
48 * @author Andrew Selkirk
50 public class TreePath
implements Serializable
52 static final long serialVersionUID
= 4380036194768077479L;
54 //-------------------------------------------------------------
55 // Variables --------------------------------------------------
56 //-------------------------------------------------------------
61 private Object
[] path
= null;
64 //-------------------------------------------------------------
65 // Initialization ---------------------------------------------
66 //-------------------------------------------------------------
69 * Constructor TreePath
72 public TreePath(Object
[] path
) {
75 this.path
= new Object
[path
.length
];
76 System
.arraycopy(path
, 0, this.path
, 0, path
.length
);
81 * Constructor TreePath
84 public TreePath(Object element
) {
93 * Constructor TreePath
97 protected TreePath(TreePath path
, Object element
) {
103 treepath
= path
.getPath();
106 this.path
= new Object
[treepath
.length
+ 1];
107 System
.arraycopy(treepath
, 0, this.path
, 0, treepath
.length
);
108 this.path
[treepath
.length
] = element
;
113 * Constructor TreePath
117 protected TreePath(Object
[] path
, int length
) {
120 this.path
= new Object
[length
];
121 System
.arraycopy(path
, 0, this.path
, 0, length
);
126 * Constructor TreePath
128 protected TreePath() {
129 path
= new Object
[0];
133 //-------------------------------------------------------------
134 // Methods ----------------------------------------------------
135 //-------------------------------------------------------------
141 public int hashCode() {
142 return getLastPathComponent().hashCode();
150 public boolean equals(Object object
) {
156 // Check for TreePath
157 if (object
instanceof TreePath
) {
160 treepath
= ((TreePath
) object
).getPath();
163 if (treepath
.length
!= path
.length
) {
168 for (index
= 0; index
< path
.length
; index
++) {
169 if (treepath
[index
] != path
[index
]) {
174 // Tree Path's are equals
188 public String
toString() {
195 * @exception IOException TODO
197 private void writeObject(ObjectOutputStream value0
) throws IOException
{
204 * @exception IOException TODO
205 * @exception ClassNotFoundException TODO
207 private void readObject(ObjectInputStream value0
) throws IOException
, ClassNotFoundException
{
215 public Object
[] getPath() {
220 * getLastPathComponent
223 public Object
getLastPathComponent() {
224 return path
[path
.length
- 1];
225 } // getLastPathComponent()
231 public int getPathCount() {
237 * @param position TODO
240 public Object
getPathComponent(int position
) {
241 return path
[position
];
242 } // getPathComponent()
249 public boolean isDescendant(TreePath path
) {
256 // Get Descendant path
257 treepath
= path
.getPath();
259 // Locate Start Index
262 while (treepath
[index
] != this.path
[index2
]) {
267 while (treepath
[index
] == this.path
[index2
]) {
272 // Check for descendant
273 if (index2
!= this.path
.length
) {
284 * @param element TODO
287 public TreePath
pathByAddingChild(Object element
) {
288 return new TreePath(this, element
);
289 } // pathByAddingChild()
295 public TreePath
getParentPath() {
296 return new TreePath(this.getPath(), path
.length
- 1);