# HG changeset patch # User jjg # Date 1211503253 25200 # Node ID 99cc2b9325f20c21e40414cbd23d2270b84e7c8e # Parent 4718b910737c9912d35d83cf849de06a9ad43b5e 6705935: javac reports path name of entry in ZipFileIndex incorectly Reviewed-by: darcy diff -r 4718b910737c -r 99cc2b9325f2 langtools/src/share/classes/com/sun/tools/javac/util/JavacFileManager.java --- a/langtools/src/share/classes/com/sun/tools/javac/util/JavacFileManager.java Thu May 22 16:06:00 2008 -0700 +++ b/langtools/src/share/classes/com/sun/tools/javac/util/JavacFileManager.java Thu May 22 17:40:53 2008 -0700 @@ -1606,7 +1606,7 @@ /** @deprecated see bug 6410637 */ @Deprecated public String getPath() { - return entry.getName() + "(" + entry + ")"; + return zipName + "(" + entry.getName() + ")"; } public long getLastModified() { diff -r 4718b910737c -r 99cc2b9325f2 langtools/test/tools/javac/6589361/T6589361.java --- a/langtools/test/tools/javac/6589361/T6589361.java Thu May 22 16:06:00 2008 -0700 +++ b/langtools/test/tools/javac/6589361/T6589361.java Thu May 22 17:40:53 2008 -0700 @@ -24,7 +24,7 @@ Iterable files = fm.list(StandardLocation.PLATFORM_CLASS_PATH, "java.lang", set, false); for (JavaFileObject file : files) { - if (file.toString().startsWith("java" + File.separator + "lang" + File.separator + "Object.class")) { + if (file.toString().contains("java" + File.separator + "lang" + File.separator + "Object.class")) { String str = fm.inferBinaryName(StandardLocation.CLASS_PATH, file); if (!str.equals("java.lang.Object")) { throw new AssertionError("Error in JavacFileManager.inferBinaryName method!"); diff -r 4718b910737c -r 99cc2b9325f2 langtools/test/tools/javac/T6705935.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/langtools/test/tools/javac/T6705935.java Thu May 22 17:40:53 2008 -0700 @@ -0,0 +1,65 @@ +/* + * Copyright 2008 Sun Microsystems, Inc. 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. + * + * 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6705935 + * @summary javac reports path name of entry in ZipFileIndex incorectly + */ + +import java.io.*; +import java.util.*; +import javax.tools.*; +import com.sun.tools.javac.util.*; + +public class T6705935 { + public static void main(String... args) throws Exception { + new T6705935().run(); + } + + public void run() throws Exception { + File java_home = new File(System.getProperty("java.home")); + if (java_home.getName().equals("jre")) + java_home = java_home.getParentFile(); + + JavaCompiler c = ToolProvider.getSystemJavaCompiler(); + JavaFileManager fm = c.getStandardFileManager(null, null, null); + for (JavaFileObject fo: fm.list(StandardLocation.PLATFORM_CLASS_PATH, + "java.lang", + Collections.singleton(JavaFileObject.Kind.CLASS), + false)) { + String p = ((BaseFileObject)fo).getPath(); + int bra = p.indexOf("("); + int ket = p.indexOf(")"); + //System.err.println(bra + "," + ket + "," + p.length()); + if (bra == -1 || ket != p.length() -1) + throw new Exception("unexpected path: " + p + "[" + bra + "," + ket + "," + p.length()); + String part1 = p.substring(0, bra); + String part2 = p.substring(bra + 1, ket); + //System.err.println("[" + part1 + "|" + part2 + "]" + " " + java_home); + if (part1.equals(part2) || !part1.startsWith(java_home.getPath())) + throw new Exception("bad path: " + p); + + } + } +}