--- a/langtools/test/tools/javac/T6705935.java Tue Oct 12 14:22:55 2010 -0700
+++ b/langtools/test/tools/javac/T6705935.java Tue Oct 12 14:47:51 2010 -0700
@@ -31,6 +31,8 @@
import java.util.*;
import javax.tools.*;
import com.sun.tools.javac.file.*;
+import com.sun.tools.javac.file.ZipArchive.ZipFileObject;
+import com.sun.tools.javac.file.ZipFileIndexArchive.ZipFileIndexFileObject;
public class T6705935 {
public static void main(String... args) throws Exception {
@@ -43,11 +45,22 @@
java_home = java_home.getParentFile();
JavaCompiler c = ToolProvider.getSystemJavaCompiler();
- JavaFileManager fm = c.getStandardFileManager(null, null, null);
+ StandardJavaFileManager fm = c.getStandardFileManager(null, null, null);
+ //System.err.println("platform class path: " + asList(fm.getLocation(StandardLocation.PLATFORM_CLASS_PATH)));
+
for (JavaFileObject fo: fm.list(StandardLocation.PLATFORM_CLASS_PATH,
"java.lang",
Collections.singleton(JavaFileObject.Kind.CLASS),
false)) {
+ test++;
+
+ if (!(fo instanceof ZipFileObject || fo instanceof ZipFileIndexFileObject)) {
+ System.out.println("Skip " + fo.getClass().getSimpleName() + " " + fo.getName());
+ skip++;
+ continue;
+ }
+
+ //System.err.println(fo.getName());
String p = fo.getName();
int bra = p.indexOf("(");
int ket = p.indexOf(")");
@@ -61,5 +74,26 @@
throw new Exception("bad path: " + p);
}
+
+ if (test == 0)
+ throw new Exception("no files found");
+
+ if (skip == 0)
+ System.out.println(test + " files found");
+ else
+ System.out.println(test + " files found, " + skip + " files skipped");
+
+ if (test == skip)
+ System.out.println("Warning: all files skipped; no platform classes found in zip files.");
}
+
+ private <T> List<T> asList(Iterable<? extends T> items) {
+ List<T> list = new ArrayList<T>();
+ for (T item: items)
+ list.add(item);
+ return list;
+ }
+
+ private int skip;
+ private int test;
}