/hg/release/icedtea6-1.11: Removed revert-6885123.patch to fix R...

ptisnovs at icedtea.classpath.org ptisnovs at icedtea.classpath.org
Thu Mar 29 08:30:19 PDT 2012


changeset a134afa67a3f in /hg/release/icedtea6-1.11
details: http://icedtea.classpath.org/hg/release/icedtea6-1.11?cmd=changeset;node=a134afa67a3f
author: ptisnovs
date: Thu Mar 29 18:28:28 2012 +0200

	Removed revert-6885123.patch to fix RH bug #789154 - javac error
	messages no longer contain the full path to the offending file.


diffstat:

 ChangeLog                    |    8 +
 Makefile.am                  |    1 -
 NEWS                         |    3 +
 patches/revert-6885123.patch |  560 -------------------------------------------
 4 files changed, 11 insertions(+), 561 deletions(-)

diffs (truncated from 610 to 500 lines):

diff -r 9543acd2586e -r a134afa67a3f ChangeLog
--- a/ChangeLog	Mon Feb 20 16:05:07 2012 +0000
+++ b/ChangeLog	Thu Mar 29 18:28:28 2012 +0200
@@ -1,3 +1,11 @@
+2012-03-29  Pavel Tisnovsky  <ptisnovs at redhat.com>
+
+	* patches/revert-6885123.patch: Removed to fix
+	  RH bug #789154 - javac error messages no longer
+	  contain the full path to the offending file.
+	* NEWS: Mention bugfix.
+	* Makefile.am: Updated.
+
 2012-02-20  Andrew Haley  <aph at redhat.com>
 
 	PR584:
diff -r 9543acd2586e -r a134afa67a3f Makefile.am
--- a/Makefile.am	Mon Feb 20 16:05:07 2012 +0000
+++ b/Makefile.am	Thu Mar 29 18:28:28 2012 +0200
@@ -346,7 +346,6 @@
 	patches/openjdk/7027667-AAShapePipeRegTest.patch \
 	patches/openjdk/7019861-AA-regression-fix.patch \
 	patches/g356743-libpng-1.5.patch \
-	patches/revert-6885123.patch \
 	patches/openjdk/7032388-work_without_cmov_instruction.patch \
 	patches/openjdk/7031385-gcc-register-allocation-fix.patch \
 	patches/openjdk/6986968-crash_on_xim_restart.patch \
diff -r 9543acd2586e -r a134afa67a3f NEWS
--- a/NEWS	Mon Feb 20 16:05:07 2012 +0000
+++ b/NEWS	Thu Mar 29 18:28:28 2012 +0200
@@ -12,6 +12,9 @@
 
 New in release 1.11.2 (2012-XX-XX):
 
+* Bug fixes
+  - RH789154: javac error messages no longer contain the full path to the offending file:
+
 New in release 1.11.1 (2012-02-14):
 
 * Security fixes
diff -r 9543acd2586e -r a134afa67a3f patches/revert-6885123.patch
--- a/patches/revert-6885123.patch	Mon Feb 20 16:05:07 2012 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,567 +0,0 @@
---- openjdk.old/langtools/src/share/classes/com/sun/tools/javac/file/RegularFileObject.java	2011-02-28 17:07:28.000000000 +0100
-+++ openjdk/langtools/src/share/classes/com/sun/tools/javac/file/RegularFileObject.java	2011-03-25 10:16:13.646180000 +0100
-@@ -78,7 +78,7 @@
- 
-     //@Override
-     public String getName() {
--        return file.getPath();
-+        return this.name;
-     }
- 
-     //@Override
---- /dev/null	1970-01-01 01:00:00.000000000 +0100
-+++ openjdk/jdk/test/javax/tools/JavaFileManager/JavaFileManagerTest.java	2011-03-28 15:51:43.000000000 +0200
-@@ -0,0 +1,119 @@
-+/*
-+ * Copyright 2011 Red Hat, 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.
-+ */
-+
-+
-+import java.util.*;
-+import java.io.*;
-+import java.nio.charset.*;
-+
-+import javax.tools.*;
-+import javax.tools.JavaFileManager.*;
-+import javax.tools.JavaFileObject.*;
-+
-+public class JavaFileManagerTest {
-+
-+    /**
-+     * Test data files are stored in a subdirectory named "test_data".
-+     */
-+    private static final String TEST_DATA_DIRECTORY = "test_data";
-+
-+    /**
-+     * Charset used by JavaFileManager.
-+     */
-+    private static final Charset FILE_MANAGER_CHARSET = Charset.forName("US-ASCII");
-+
-+    /**
-+     * Locale used by JavaFileManager.
-+     */
-+    private static final Locale FILE_MANAGER_LOCALE = (java.util.Locale)null;
-+
-+    /**
-+     * Location of file objects being tested.
-+     */
-+    private static final Location FILE_OBJECTS_LOCATION = javax.tools.StandardLocation.SOURCE_PATH;
-+
-+    public static DiagnosticListener<JavaFileObject> listener = new DiagnosticCollector<JavaFileObject>();
-+
-+    private void doTest() throws IOException {
-+        StandardJavaFileManager fileManager = getStandardFileManager();
-+        fileManager.setLocation(FILE_OBJECTS_LOCATION, Collections.singleton(getSourceDirPathFile()));
-+
-+        checkFileManagerLocation(fileManager.getLocation(FILE_OBJECTS_LOCATION));
-+        checkFileManagerGetName(fileManager);
-+    }
-+
-+    private StandardJavaFileManager getStandardFileManager() {
-+        return ToolProvider.getSystemJavaCompiler().getStandardFileManager(
-+                listener, FILE_MANAGER_LOCALE, FILE_MANAGER_CHARSET);
-+    }
-+
-+    public static File getSourceDirPathFile() {
-+        return new File(new File("."), TEST_DATA_DIRECTORY);
-+    }
-+
-+    /**
-+     * Check if there's "./test_data" location included in a locations argument.
-+     * @param locations set of locations returned by fileManager.getLocation()
-+     */
-+    private void checkFileManagerLocation(Iterable<? extends File> locations) {
-+        for (File file : locations) {
-+            if (".".equals(file.getParent()) && TEST_DATA_DIRECTORY.equals(file.getName())) {
-+                System.out.println("checkFileManagerLocation: ok");
-+                return;
-+            }
-+        }
-+        throw new RuntimeException("fileManager.getLocation() returns wrong locations! " + locations.toString());
-+    }
-+
-+    /**
-+     * Check if method JavaFileManager.getName() returns correct file name.
-+     * @param fileManager
-+     * @throws IOException
-+     */
-+    private void checkFileManagerGetName(JavaFileManager fileManager) throws IOException {
-+        Map<Kind, String> kinds = new HashMap<Kind, String>();
-+        kinds.put(Kind.SOURCE, "Test.java");
-+        kinds.put(Kind.CLASS,  "Test.class");
-+        kinds.put(Kind.HTML,   "Test.html");
-+        kinds.put(Kind.OTHER,  "Test.txt");
-+        for (Map.Entry<Kind, String> kind : kinds.entrySet()) {
-+            System.out.println("Testing JavaFileManager for kind " + kind.getKey());
-+            Iterable<JavaFileObject> fileObjects = fileManager.list(
-+                    FILE_OBJECTS_LOCATION, "", Collections.singleton(kind.getKey()), false);
-+            checkIfFileObjectsContainName(fileObjects, kind.getValue());
-+        }
-+    }
-+
-+    private void checkIfFileObjectsContainName(Iterable<JavaFileObject> fileObjects, String name) {
-+        //System.out.println(fileObjects);
-+        for (JavaFileObject fileObject : fileObjects) {
-+            //System.out.println(fileObject.getName());
-+            if (name.equals(fileObject.getName())) {
-+                System.out.println("JavaFileObject.getName(): ok  ('" + fileObject.getName() + "')");
-+                return;
-+            }
-+        }
-+        throw new RuntimeException("JavaFileObject.getName() returns wrong name!");
-+    }
-+
-+    public static void main(String argv[]) throws IOException {
-+        new JavaFileManagerTest().doTest();
-+    }
-+
-+}
---- /dev/null	1970-01-01 01:00:00.000000000 +0100
-+++ openjdk/jdk/test/javax/tools/JavaFileManager/JavaFileManagerTest.sh	2011-03-28 15:47:23.000000000 +0200
-@@ -0,0 +1,153 @@
-+#!/bin/sh
-+
-+#
-+# Copyright 2011 Red Hat, 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.
-+
-+#
-+# This script is the actual launcher of JavaFileManagerTest.java
-+# 
-+
-+# @test
-+# @summary Test that check proper behaviour of JavaFileManager and
-+#          JavaFileObject classes.
-+
-+
-+
-+# check arguments set by JTreg
-+checkArgs() {
-+    if [ "${TESTSRC}" = "" ]
-+    then
-+        echo "TESTSRC not set.  Test cannot execute.  Failed."
-+        exit 1
-+    fi
-+    echo "TESTSRC=${TESTSRC}"
-+    if [ "${TESTJAVA}" = "" ]
-+    then
-+        echo "TESTJAVA not set.  Test cannot execute.  Failed."
-+        exit 1
-+    fi
-+    echo "TESTJAVA=${TESTJAVA}"
-+    if [ "${TESTCLASSES}" = "" ]
-+    then
-+        echo "TESTCLASSES not set.  Test cannot execute.  Failed."
-+        exit 1
-+    fi
-+}
-+
-+
-+
-+# print paths to test sources and test classes
-+printPaths() {
-+    echo "TESTCLASSES=${TESTCLASSES}"
-+    echo "CLASSPATH=${CLASSPATH}"
-+}
-+
-+
-+
-+# copy of all necessarry files into work directory
-+copyWorkFiles() {
-+    cp -r "${TESTSRC}/test_data" "${TESTCLASSES}/"
-+    result=$?
-+    if [ $result -eq 0 ]
-+    then
-+        echo "Copy of work files was successful."
-+    else 
-+        echo "copy of work files have failed."
-+        exit $result
-+    fi
-+
-+    cp "${TESTSRC}/JavaFileManagerTest.java" "${TESTCLASSES}"
-+    result=$?
-+    if [ $result -eq 0 ]
-+    then
-+        echo "Copy of work files was successful."
-+    else 
-+        echo "copy of work files have failed."
-+        exit $result
-+    fi
-+}
-+
-+
-+
-+# compilation of Test class which is stored in test_data subdirectory
-+compileTestClass() {
-+    COMPILE="${TESTJAVA}/bin/javac ${TESTCLASSES}/test_data/Test.java"
-+    echo ${COMPILE}
-+    ${COMPILE}
-+    result=$?
-+
-+    if [ $result -eq 0 ]
-+    then
-+        echo "Compilation of the test class was successful."
-+    else 
-+        echo "Compilation of the test class have failed."
-+        # Cleanup
-+        rm -rf ${TESTCLASSES}/
-+        exit $result
-+    fi
-+}
-+
-+
-+
-+# compilation of the Test itself
-+compileTest() {
-+    COMPILE="${TESTJAVA}/bin/javac ${TESTCLASSES}/JavaFileManagerTest.java"
-+    echo ${COMPILE}
-+    ${COMPILE}
-+    result=$?
-+
-+    if [ $result -eq 0 ]
-+    then
-+        echo "Compilation of the test case was successful."
-+    else 
-+        echo "Compilation of the test case failed."
-+        # Cleanup
-+        rm -rf ${TESTCLASSES}/
-+        exit $result
-+    fi
-+}
-+
-+
-+
-+# run the test
-+runTest() {
-+    cd ${TESTCLASSES}
-+    RUNCMD="${TESTJAVA}/bin/java JavaFileManagerTest"
-+    echo ${RUNCMD}
-+    ${RUNCMD}
-+    result=$?
-+
-+    if [ $result -eq 0 ]
-+    then
-+        echo "Execution successful"
-+    else
-+        echo "Execution of the test case failed."
-+    fi
-+    rm -rf ${TESTCLASSES}/
-+    exit $result
-+}
-+
-+
-+
-+checkArgs
-+printPaths
-+copyWorkFiles
-+compileTestClass
-+compileTest
-+runTest
-+
---- /dev/null	1970-01-01 01:00:00.000000000 +0100
-+++ openjdk/jdk/test/javax/tools/JavaFileManager/test_data/Test.html	2011-03-25 18:19:45.000000000 +0100
-@@ -0,0 +1,5 @@
-+<html>
-+<body>
-+42
-+</body>
-+</html>
---- /dev/null	1970-01-01 01:00:00.000000000 +0100
-+++ openjdk/jdk/test/javax/tools/JavaFileManager/test_data/Test.java	2011-03-28 14:53:50.000000000 +0200
-@@ -0,0 +1,5 @@
-+package test_data;
-+
-+public class Test {
-+	// nothing here
-+}
---- /dev/null	1970-01-01 01:00:00.000000000 +0100
-+++ openjdk/jdk/test/javax/tools/JavaFileManager/test_data/Test.txt	2011-03-28 16:15:09.000000000 +0200
-@@ -0,0 +1,2 @@
-+42
-+
---- openjdk/langtools/test/tools/javac/api/6411310/Test.java	2011-02-28 17:07:32.000000000 +0100
-+++ /dev/null	2011-03-27 16:20:13.277479669 +0200
-@@ -1,254 +0,0 @@
--/*
-- * Copyright (c) 2009, 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.
-- *
-- * 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.
-- */
--
--/*
-- * @test
-- * @bug 6410367 6411310
-- * @summary FileObject should support user-friendly names via getName()
-- */
--
--import java.io.*;
--import java.util.*;
--import java.util.jar.*;
--import java.util.zip.*;
--import javax.tools.*;
--
--import com.sun.tools.javac.file.JavacFileManager;
--import com.sun.tools.javac.util.Context;
--import com.sun.tools.javac.util.Options;
--
--// Test FileObject.getName returned from JavacFileManager and its support classes.
--
--public class Test {
--    public static void main(String... args) throws Exception {
--        new Test().run();
--    }
--
--    Set<String> foundClasses = new TreeSet<String>();
--    Set<String> foundJars = new TreeSet<String>();
--
--    void run() throws Exception {
--        File rt_jar = findRtJar();
--
--        // names for entries to be created in directories and jar files
--        String[] entries = { "p/A.java", "p/A.class", "p/resources/A-1.html" };
--
--        // test various combinations of directories and jar files, intended to
--        // cover all sources of file objects within JavacFileManager's support classes
--
--        test(createFileManager(), createDir("dir", entries), "p", entries);
--        test(createFileManager(), createDir("a b/dir", entries), "p", entries);
--
--        for (boolean useJavaUtilZip: new boolean[] { false, true }) {
--            test(createFileManager(useJavaUtilZip), createJar("jar", entries), "p", entries);
--            test(createFileManager(useJavaUtilZip), createJar("jar jar", entries), "p", entries);
--
--            for (boolean useSymbolFile: new boolean[] { false, true }) {
--                test(createFileManager(useJavaUtilZip, useSymbolFile), rt_jar, "java.lang.ref", null);
--            }
--        }
--
--        if (errors > 0)
--            throw new Exception(errors + " errors found");
--
--        // Verify that we hit all the impl classes we intended
--        checkCoverage("classes", foundClasses,
--                "RegularFileObject", "SymbolFileObject", "ZipFileIndexFileObject", "ZipFileObject");
--
--        // Verify that we hit the jar files we intended, specifically ct.sym as well as rt.jar
--        checkCoverage("jar files", foundJars,
--                "ct.sym", "jar", "jar jar", "rt.jar");
--    }
--
--    // use a new file manager for each test
--    void test(StandardJavaFileManager fm, File f, String pkg, String[] entries) throws Exception {
--        System.err.println("Test " + f);
--        try {
--            if (f.isDirectory()) {
--                for (File dir: new File[] { f, f.getAbsoluteFile() }) {
--                    for (String e: entries) {
--                        JavaFileObject fo = fm.getJavaFileObjects(new File(dir, e)).iterator().next();
--                        test(fo, dir, e);
--                    }
--                }
--            }
--
--            fm.setLocation(StandardLocation.CLASS_PATH, Collections.singleton(f));
--            fm.setLocation(StandardLocation.SOURCE_PATH, Collections.singleton(f.getAbsoluteFile()));
--            for (StandardLocation l: EnumSet.of(StandardLocation.CLASS_PATH, StandardLocation.SOURCE_PATH)) {
--                for (JavaFileObject fo: fm.list(l, pkg, EnumSet.allOf(JavaFileObject.Kind.class), true)) {
--                    // we could use fm.getLocation but the following guarantees we preserve the original filename
--                    File dir = (l == StandardLocation.CLASS_PATH ? f : f.getAbsoluteFile());
--                    char sep = (dir.isDirectory() ? File.separatorChar : '/');
--                    String b = fm.inferBinaryName(l, fo);
--                    String e = fo.getKind().extension;
--                    test(fo, dir, b.replace('.', sep) + e);
--                }
--            }
--        } finally {
--            fm.close();
--        }
--    }
--
--    void test(JavaFileObject fo, File dir, String p) {
--        System.err.println("Test: " + fo);
--        String expect = dir.isDirectory() ? new File(dir, p).getPath() : (dir.getPath() + "(" + p + ")");
--        String found = fo.getName();
--        // if ct.sym is found, replace it with the equivalent rt.jar
--        String found2 = found.replaceAll("lib([\\\\/])ct.sym\\(META-INF/sym/rt.jar/", "jre$1lib$1rt.jar(");
--        if (!expect.equals(found2)) {
--            System.err.println("expected: " + expect);
--            System.err.println("   found: " + found);
--            if (!found.equals(found2))
--                System.err.println("  found2: " + found2);
--            error("Failed: " + fo);
--        }
--
--        // record the file object class name for coverage checks later
--        foundClasses.add(fo.getClass().getSimpleName());
--
--        if (found.contains("(")) {
--            // record access to the jar file for coverage checks later
--            foundJars.add(new File(found.substring(0, found.indexOf("("))).getName());
--        }
--    }
--
--    void checkCoverage(String label, Set<String> found, String... expect) throws Exception {
--        Set<String> e = new TreeSet<String>(Arrays.asList(expect));
--        if (!found.equals(e)) {
--            e.removeAll(found);
--            throw new Exception("expected " + label + " not used: " + e);
--        }
--    }
--
--    JavacFileManager createFileManager() {



More information about the distro-pkg-dev mailing list