diff --git a/langtools/src/share/classes/com/sun/tools/javac/code/Types.java b/langtools/src/share/classes/com/sun/tools/javac/code/Types.java index 57b49b821c2cbecb2a430c50237985cb6ecf71ea..4ab94d767497f63f6adf45643ec3e50deffc185b 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/code/Types.java +++ b/langtools/src/share/classes/com/sun/tools/javac/code/Types.java @@ -915,7 +915,7 @@ public class Types { return true; if (t.isPrimitive() != s.isPrimitive()) - return allowBoxing && isConvertible(t, s, warn); + return allowBoxing && (isConvertible(t, s, warn) || isConvertible(s, t, warn)); if (warn != warnStack.head) { try { diff --git a/langtools/src/share/classes/com/sun/tools/javac/comp/Lower.java b/langtools/src/share/classes/com/sun/tools/javac/comp/Lower.java index 813b3500d2c172a6d27862f00ea26a2a4d1f085c..c7ffb485946c8b628d812da3d911ba618391e929 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/comp/Lower.java +++ b/langtools/src/share/classes/com/sun/tools/javac/comp/Lower.java @@ -2889,8 +2889,17 @@ public class Lower extends TreeTranslator { /** Unbox an object to a primitive value. */ JCExpression unbox(JCExpression tree, Type primitive) { Type unboxedType = types.unboxedType(tree.type); - // note: the "primitive" parameter is not used. There muse be - // a conversion from unboxedType to primitive. + if (unboxedType.tag == NONE) { + unboxedType = primitive; + if (!unboxedType.isPrimitive()) + throw new AssertionError(unboxedType); + make_at(tree.pos()); + tree = make.TypeCast(types.boxedClass(unboxedType).type, tree); + } else { + // There must be a conversion from unboxedType to primitive. + if (!types.isSubtype(unboxedType, primitive)) + throw new AssertionError(tree); + } make_at(tree.pos()); Symbol valueSym = lookupMethod(tree.pos(), unboxedType.tsym.name.append(names.Value), // x.intValue() diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD34.java b/langtools/test/tools/javac/6979683/TestCast6979683_BAD34.java new file mode 100644 index 0000000000000000000000000000000000000000..d58b2ce96975dcf05266d13ac513093717fd9cc5 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD34.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile/fail/ref=TestCast6979683_BAD34.java.errlog -XDrawDiagnostics TestCast6979683_BAD34.java + */ + +public class TestCast6979683_BAD34 { + static boolean zconvBAD1(Number o) { return o; } //BAD + //... + //... + //... + //... + //... +} diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD34.java.errlog b/langtools/test/tools/javac/6979683/TestCast6979683_BAD34.java.errlog new file mode 100644 index 0000000000000000000000000000000000000000..d43be7b22b5d8cb92ea3dde61fad6051b1ea76b3 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD34.java.errlog @@ -0,0 +1,2 @@ +TestCast6979683_BAD34.java:34:49: compiler.err.prob.found.req: (compiler.misc.incompatible.types), java.lang.Number, boolean +1 error diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD35.java b/langtools/test/tools/javac/6979683/TestCast6979683_BAD35.java new file mode 100644 index 0000000000000000000000000000000000000000..d738f273e9651d83aaa62e23d510c9ee2a9e4d9e --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD35.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile/fail/ref=TestCast6979683_BAD35.java.errlog -XDrawDiagnostics TestCast6979683_BAD35.java + */ + +public class TestCast6979683_BAD35 { + //... + static int iconvBAD1(Number o) { return o; } //BAD: cast needed + //... + //... + //... + //... +} diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD35.java.errlog b/langtools/test/tools/javac/6979683/TestCast6979683_BAD35.java.errlog new file mode 100644 index 0000000000000000000000000000000000000000..270f5b79bd5fd4c28a9f324d41d3e1d0b7da7b63 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD35.java.errlog @@ -0,0 +1,2 @@ +TestCast6979683_BAD35.java:35:45: compiler.err.prob.found.req: (compiler.misc.incompatible.types), java.lang.Number, int +1 error diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD36.java b/langtools/test/tools/javac/6979683/TestCast6979683_BAD36.java new file mode 100644 index 0000000000000000000000000000000000000000..a86137367a755474b122e7f7d1f1c73b2d0423e6 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD36.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile/fail/ref=TestCast6979683_BAD36.java.errlog -XDrawDiagnostics TestCast6979683_BAD36.java + */ + +public class TestCast6979683_BAD36 { + //... + //... + static int iconvBAD2(Comparable o) { return o; } //BAD: cast needed + //... + //... + //... +} diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD36.java.errlog b/langtools/test/tools/javac/6979683/TestCast6979683_BAD36.java.errlog new file mode 100644 index 0000000000000000000000000000000000000000..f4338d82550e212c62cd8a91e928dbe022d010e3 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD36.java.errlog @@ -0,0 +1,2 @@ +TestCast6979683_BAD36.java:36:58: compiler.err.prob.found.req: (compiler.misc.incompatible.types), java.lang.Comparable, int +1 error diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD37.java b/langtools/test/tools/javac/6979683/TestCast6979683_BAD37.java new file mode 100644 index 0000000000000000000000000000000000000000..f972b5337f893aafc443b084d13c01599b57786e --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD37.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile/fail/ref=TestCast6979683_BAD37.java.errlog -XDrawDiagnostics TestCast6979683_BAD37.java + */ + +public class TestCast6979683_BAD37 { + //... + //... + //... + static int iconvBAD3(Comparable o) { return (int)o; } //BAD: wrong instance + //... + //... +} diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD37.java.errlog b/langtools/test/tools/javac/6979683/TestCast6979683_BAD37.java.errlog new file mode 100644 index 0000000000000000000000000000000000000000..89b7a57418db4abbf1d3a7a2525d2db270d59545 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD37.java.errlog @@ -0,0 +1,2 @@ +TestCast6979683_BAD37.java:37:61: compiler.err.prob.found.req: (compiler.misc.inconvertible.types), java.lang.Comparable, int +1 error diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD38.java b/langtools/test/tools/javac/6979683/TestCast6979683_BAD38.java new file mode 100644 index 0000000000000000000000000000000000000000..043fa452619bca5a0d433cdd27c95fa5f8b686c6 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD38.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile/fail/ref=TestCast6979683_BAD38.java.errlog -XDrawDiagnostics TestCast6979683_BAD38.java + */ + +public class TestCast6979683_BAD38 { + //... + //... + //... + //... + static float cconvBAD1(Comparable o) { return o; } //BAD + //... +} diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD38.java.errlog b/langtools/test/tools/javac/6979683/TestCast6979683_BAD38.java.errlog new file mode 100644 index 0000000000000000000000000000000000000000..47d617aec10e81e5deaff53e11a1590463841edf --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD38.java.errlog @@ -0,0 +1,2 @@ +TestCast6979683_BAD38.java:38:62: compiler.err.prob.found.req: (compiler.misc.incompatible.types), java.lang.Comparable, float +1 error diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD39.java b/langtools/test/tools/javac/6979683/TestCast6979683_BAD39.java new file mode 100644 index 0000000000000000000000000000000000000000..ab11d0d78ff2440e569fccd27c11fa0238b15ee6 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD39.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile/fail/ref=TestCast6979683_BAD39.java.errlog -XDrawDiagnostics TestCast6979683_BAD39.java + */ + +public class TestCast6979683_BAD39 { + //... + //... + //... + //... + //... + static float cconvBAD2(Number o) { return (char)o; } //BAD +} diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_BAD39.java.errlog b/langtools/test/tools/javac/6979683/TestCast6979683_BAD39.java.errlog new file mode 100644 index 0000000000000000000000000000000000000000..9f41dfa56d1e675b6a95cdbb6d1b7b43d6b2df72 --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_BAD39.java.errlog @@ -0,0 +1,2 @@ +TestCast6979683_BAD39.java:39:53: compiler.err.prob.found.req: (compiler.misc.inconvertible.types), java.lang.Number, char +1 error diff --git a/langtools/test/tools/javac/6979683/TestCast6979683_GOOD.java b/langtools/test/tools/javac/6979683/TestCast6979683_GOOD.java new file mode 100644 index 0000000000000000000000000000000000000000..594d0f42440bb84b549ec9072851e52e0822dc3f --- /dev/null +++ b/langtools/test/tools/javac/6979683/TestCast6979683_GOOD.java @@ -0,0 +1,111 @@ +/* + * Copyright (c) 2010, 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 6979683 + * @summary Verify that casts can narrow and unbox at the same time + * @author jrose + * + * @compile TestCast6979683_GOOD.java + * @run main TestCast6979683_GOOD + */ + +public class TestCast6979683_GOOD { + public static void main(String... av) { + bugReportExample(); + for (int x = -1; x <= 2; x++) { + zconvTests(x != 0); + iconvTests(x); + bconvTests((byte)x); + cconvTests((char)x); + } + System.out.println("Successfully ran "+tests+" tests."); + } + + static int tests; + static void assertEquals(Object x, Object y) { + if (!x.equals(y)) { + throw new RuntimeException("assertEquals: "+x+" != "+y); + } + ++tests; + } + + static void bugReportExample() { + {} // example in bug report: + Object x = (Object)1; + int y = (int)x; + {} // end example + } + + static boolean zconv1(Boolean o) { return o; } + static boolean zconv2(Object o) { return (boolean)o; } + static boolean zconv3(Comparable o) { return (boolean)o; } + + static void zconvTests(boolean x) { + assertEquals(x, zconv1(x)); + assertEquals(x, zconv2(x)); + assertEquals(x, zconv3(x)); + } + + static int iconv1(Integer o) { return o; } + static int iconv2(Object o) { return (int)o; } + static int iconv3(java.io.Serializable o) { return (int)o; } + static int iconv4(Number o) { return (int)o; } + static int iconv5(Comparable o) { return (int)o; } + + static void iconvTests(int x) { + assertEquals(x, iconv1(x)); + assertEquals(x, iconv2(x)); + assertEquals(x, iconv3(x)); + assertEquals(x, iconv4(x)); + assertEquals(x, iconv5(x)); + } + + static float bconv1(Byte o) { return o; } // note type "float" + static float bconv2(Object o) { return (byte)o; } + static float bconv3(java.io.Serializable o) { return (byte)o; } + static float bconv4(Number o) { return (byte)o; } + + static void bconvTests(byte x) { + float xf = x; + assertEquals(xf, bconv1(x)); + assertEquals(xf, bconv2(x)); + assertEquals(xf, bconv3(x)); + assertEquals(xf, bconv4(x)); + } + + static float cconv1(Character o) { return o; } // note type "float" + static float cconv2(Object o) { return (char)o; } + static float cconv3(java.io.Serializable o) { return (char)o; } + static float cconv4(Comparable o) { return (char)o; } + + static void cconvTests(char x) { + float xf = x; + assertEquals(xf, cconv1(x)); + assertEquals(xf, cconv2(x)); + assertEquals(xf, cconv3(x)); + assertEquals(xf, cconv4(x)); + } + +}