/*
* Copyright (c) 1998, 2011, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code 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
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* This source code is provided to illustrate the usage of a given feature
* or technique and has been deliberately simplified. Additional steps
* required for a production-quality application, such as security checks,
* input validation and proper error handling, might not be present in
* this sample code.
*/
package com.sun.tools.example.debug.tty;
import com.sun.jdi.Location;
import com.sun.jdi.AbsentInformationException;
import java.util.List;
import java.util.ArrayList;
import java.util.StringTokenizer;
import java.io.*;
class SourceMapper {
private final String[] dirs;
SourceMapper(List<String> sourcepath) {
/*
* sourcepath can arrive from the debugee as a List.
* (via PathSearchingVirtualMachine.classPath())
*/
List<String> dirList = new ArrayList<String>();
for (String element : sourcepath) {
//XXX remove .jar and .zip files; we want only directories on
//the source path. (Bug ID 4186582)
if ( ! (element.endsWith(".jar") ||
element.endsWith(".zip"))) {
dirList.add(element);
}
}
dirs = dirList.toArray(new String[0]);
}
SourceMapper(String sourcepath) {
/*
* sourcepath can also arrive from the command line
* as a String. (via "-sourcepath")
*
* Using File.pathSeparator as delimiter below is OK
* because we are on the same machine as the command
* line originiated.
*/
StringTokenizer st = new StringTokenizer(sourcepath,
File.pathSeparator);
List<String> dirList = new ArrayList<String>();
while (st.hasMoreTokens()) {
String s = st.nextToken();
//XXX remove .jar and .zip files; we want only directories on
//the source path. (Bug ID 4186582)
if ( ! (s.endsWith(".jar") ||
s.endsWith(".zip"))) {
dirList.add(s);
}
}
dirs = dirList.toArray(new String[0]);
}
/*
* Return the current sourcePath as a String.
*/
String getSourcePath() {
int i = 0;
StringBuffer sp;
if (dirs.length < 1) {
return ""; //The source path is empty.
} else {
sp = new StringBuffer(dirs[i++]);
}
for (; i < dirs.length; i++) {
sp.append(File.pathSeparator);
sp.append(dirs[i]);
}
return sp.toString();
}
Return a File cooresponding to the source of this location.
Return null if not available.
/**
* Return a File cooresponding to the source of this location.
* Return null if not available.
*/
File sourceFile(Location loc) {
try {
String filename = loc.sourceName();
String refName = loc.declaringType().name();
int iDot = refName.lastIndexOf('.');
String pkgName = (iDot >= 0)? refName.substring(0, iDot+1) : "";
String full = pkgName.replace('.', File.separatorChar) + filename;
for (int i= 0; i < dirs.length; ++i) {
File path = new File(dirs[i], full);
if (path.exists()) {
return path;
}
}
return null;
} catch (AbsentInformationException e) {
return null;
}
}
Return a BufferedReader cooresponding to the source
of this location.
Return null if not available.
Note: returned reader must be closed.
/**
* Return a BufferedReader cooresponding to the source
* of this location.
* Return null if not available.
* Note: returned reader must be closed.
*/
BufferedReader sourceReader(Location loc) {
File sourceFile = sourceFile(loc);
if (sourceFile == null) {
return null;
}
try {
return new BufferedReader(new FileReader(sourceFile));
} catch(IOException exc) {
}
return null;
}
}