⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 searchpath.java

📁 已经移植好的java虚拟机
💻 JAVA
字号:
/* * @(#)SearchPath.java	1.4 99/05/21 * * Copyright (c) 1997-1999 by Sun Microsystems, Inc. All Rights Reserved. *  * Sun grants you ("Licensee") a non-exclusive, royalty free, license to use, * modify and redistribute this software in source and binary code form, * provided that i) this copyright notice and license appear on all copies of * the software; and ii) Licensee does not utilize the software in a manner * which is disparaging to Sun. *  * This software is provided "AS IS," without a warranty of any kind. ALL * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY * IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR * NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE * LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING * OR DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR ITS * LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT, * INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER * CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF * OR INABILITY TO USE SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE * POSSIBILITY OF SUCH DAMAGES. *  * This software is not designed or intended for use in on-line control of * aircraft, air traffic, aircraft navigation or aircraft communications; or in * the design, construction, operation or maintenance of any nuclear * facility. Licensee represents and warrants that it will not use or * redistribute the Software for such purposes. * Use is subject to license terms. */package kdp.classparser;import kdp.Log;import java.io.*;import java.util.*;import java.lang.*;public class SearchPath {    private String pathString;    private String[] pathArray;    public SearchPath(String searchPath) {	//### Should check searchpath for well-formedness.	StringTokenizer st = new StringTokenizer(searchPath, File.pathSeparator);	List dlist = new ArrayList();	while (st.hasMoreTokens()) {	    dlist.add(st.nextToken());	}	pathString = searchPath;        Log.LOGN(3,  "!!!" + pathString );	pathArray = (String[])dlist.toArray(new String[dlist.size()]);	Log.LOGN(3, "Path array length is :"+pathArray.length);	for(int i=0; i<pathArray.length; i++) {		Log.LOGN(3, pathArray[i]);	}    }    public boolean isEmpty() {	return (pathArray.length == 0);    }    public String asString() {	return pathString;    }        public String[] asArray() {	return (String[])pathArray.clone();    }		public int path_array_length() {		return pathArray.length;	}    public FileReference resolve(String relativeFileName) {		Log.LOGN(4, "relative filename = " + relativeFileName);		Log.LOGN(4, "path array length in resolve is " +pathArray.length);	if (!relativeFileName.endsWith(".class"))		relativeFileName += ".class";	Log.LOGN(4, "relative filename now = " + relativeFileName);        for (int i = 0; i < pathArray.length; i++) {//			Log.LOGN(3, "path array = " + pathArray[i]);//			Log.LOGN(3, "relativeFileName);            Log.LOGN(5,  "pa=" + pathArray[ i ] + " " +                                "rfa=" + relativeFileName );            FileReference path = FileReference.create(pathArray[i], relativeFileName);            if (path.exists()) {                Log.LOGN(4,  "  exists" );				return path;            }        }        return null;    }    //### return List?    public String[] children(String relativeDirName, FilenameFilter filter) {	// If a file appears at the same relative path	// with respect to multiple entries on the classpath,	// the one corresponding to the earliest entry on the	// classpath is retained.  This is the one that will be	// found if we later do a 'resolve'.	SortedSet s = new TreeSet();  // sorted, no duplicates        for (int i = 0; i < pathArray.length; i++) {            FileReference path = FileReference.create(pathArray[i], relativeDirName);            if (path.exists()) {		String[] childArray = path.list(filter);		if (childArray != null) {		    for (int j = 0; j < childArray.length; j++) {			if (!s.contains(childArray[j])) {			    s.add(childArray[j]);			}		    }		}	    }	}        return (String[])s.toArray(new String[s.size()]);    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -